﻿<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type='text/css' href='https://stocksharp.ru/css/style.css'?>
<?xml-stylesheet type='text/css' href='https://stocksharp.ru/css/bbeditor.css'?>
<feed xmlns="http://www.w3.org/2005/Atom">
  <title type="html">конвертация  текстового ордерлога в S#</title>
  <id>~/topic/3312/konvertatsiya--tekstovogo-orderloga-v-s/</id>
  <rights type="text">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  <updated>2026-06-21T13:58:59Z</updated>
  <logo>https://stocksharp.ru/images/logo.png</logo>
  <link href="https://stocksharp.ru/handlers/atom.ashx?category=topic&amp;id=3312" rel="self" type="application/rss+xml" />
  <entry>
    <id>https://stocksharp.ru/posts/m/23535/</id>
    <title type="text">Без статуса не получится ничего. Пример конвертации ОЛ </title>
    <published>2013-01-18T18:31:54Z</published>
    <updated>2016-08-16T00:11:20Z</updated>
    <author>
      <name>Garic</name>
      <uri>https://stocksharp.ru/users/809/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;p&gt;Без статуса не получится ничего.
&lt;a href="http://stocksharp.com/posts/m/21014/"&gt;Пример конвертации ОЛ&lt;/a&gt;&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.ru/posts/m/23531/</id>
    <title type="text">Андрей Шабанов: то есть без информации order.status ничего тестировать не удастся? Вы по ссылке прой...</title>
    <published>2013-01-18T14:13:24Z</published>
    <updated>2013-01-18T14:13:24Z</updated>
    <author>
      <name>Mikhail Sukhov</name>
      <uri>https://stocksharp.ru/users/201/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;&lt;a href="@message(23530)" rel="nofollow" target="_blank"&gt;Андрей Шабанов&lt;/a&gt;:&lt;/strong&gt;
то есть без информации order.status ничего тестировать не удастся?&lt;/p&gt;
&lt;/blockquote&gt;
&lt;p&gt;Вы по ссылке пройдите. Там доходчиво сотрудник РТС написал про назначение этого поля.&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.ru/posts/m/23530/</id>
    <title type="text">то есть без информации order.status ничего тестировать не удастся? необходимо писать гидрой? даже ес...</title>
    <published>2013-01-18T13:47:47Z</published>
    <updated>2013-01-18T13:48:40Z</updated>
    <author>
      <name>Андрей Шабанов</name>
      <uri>https://stocksharp.ru/users/16691/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;p&gt;то есть без информации order.status ничего тестировать не удастся? необходимо писать гидрой?
даже если я буду писать что=нибудь типа&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;
order.Status=OrderStatus.Accepted

&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;и&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;
trade.Status=1;

&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;еще на строчке.
orderlogStorage.Save(orderlogItems);
выкидывает NullReferenceException.
c чем это может быть связано?&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;
            var security = new Security
             {
                 Id = tbx_id.Text,
                 MinStepSize = decimal.Parse(tbx_MinStep.Text),
                 Decimals = int.Parse(tbx_Decimals.Text),
             };

            var orderlogItems = new List&amp;lt;OrderLogItem&amp;gt;();
            var storage = new StorageRegistry();
            var orderlogStorage = storage.GetOrderLogStorage(security);
            string file = filenames[0];

            StreamReader Sr = new StreamReader(path + @&amp;quot;\&amp;quot; + file);
            string CurrentLine = Sr.ReadLine();
            while ((CurrentLine = Sr.ReadLine()) != null)
            {
                string[] Split = CurrentLine.Split(',');
                if (Split[0] == security.Id.Split('@')[0])
                {
                    var orderlogItem = new OrderLogItem();
                    var order = new Order();
                    var trade = new Trade();
                    if (Split[5] == &amp;quot;2&amp;quot;)
                    {
                        //order = null;
                        trade.Time = DateTime.ParseExact(Split[3], &amp;quot;yyyyMMddHHmmssfff&amp;quot;, CultureInfo.InvariantCulture, DateTimeStyles.None);
                        trade.OrderDirection = (Split[2] == &amp;quot;B&amp;quot; ? OrderDirections.Buy : OrderDirections.Sell);
                        trade.Security = security;
                        trade.Id = Int64.Parse(Split[8]);
                        trade.Price = Decimal.Parse(Split[9], CultureInfo.InvariantCulture);
                        trade.Volume = int.Parse(Split[7]);
                        trade.Status = 1;
                        orderlogItem.Trade = trade;

                    }
                    else
                    {
                       //trader=null;
                        order.Time = DateTime.ParseExact(Split[3], &amp;quot;yyyyMMddHHmmssfff&amp;quot;, CultureInfo.InvariantCulture, DateTimeStyles.None);
                        order.Direction = (Split[2] == &amp;quot;B&amp;quot; ? OrderDirections.Buy : OrderDirections.Sell);
                        order.Security = security;
                        order.Id = Int64.Parse(Split[4]);
                        order.Price = Decimal.Parse(Split[6], CultureInfo.InvariantCulture);
                        order.Volume = int.Parse(Split[7]);
                        order.State = (Split[5] == &amp;quot;1&amp;quot;) ? OrderStates.Active : OrderStates.Done;
                        orderlogItem.Order = order;
                        order.Status = OrderStatus.Accepted;


                    }


                    //orderlogItem.Order = order;
                    //orderlogItem.Trade = trade;
                    orderlogItems.Add(orderlogItem);
                    if (orderlogItems.Count &amp;gt;= buff)
                    {
                        orderlogStorage.Save(orderlogItems);
                        orderlogItems.Clear();
                    }
                }

            }
            if(orderlogItems.Count!=0)
                orderlogStorage.Save(orderlogItems);
            orderlogItems.Clear();
            
            Sr.Close();

        }

&lt;/code&gt;&lt;/pre&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.ru/posts/m/23529/</id>
    <title type="text">Без статуса грустно http://forum.rts.micex.ru/viewtopic.asp?t=24197 Стаканы не собрать правильно </title>
    <published>2013-01-18T13:03:42Z</published>
    <updated>2013-01-18T13:03:53Z</updated>
    <author>
      <name>Mikhail Sukhov</name>
      <uri>https://stocksharp.ru/users/201/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;p&gt;Без статуса грустно &lt;a href="http://forum.rts.micex.ru/viewtopic.asp?t=24197" rel="nofollow" target="_blank"&gt;http://forum.rts.micex.ru/viewtopic.asp?t=24197&lt;/a&gt; Стаканы не собрать правильно&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.ru/posts/m/23528/</id>
    <title type="text">Добрый день, извините за беспокойство. Задача следующая есть своя история full ордерлога в формате: ...</title>
    <published>2013-01-18T11:18:24Z</published>
    <updated>2013-01-18T12:05:48Z</updated>
    <author>
      <name>Андрей Шабанов</name>
      <uri>https://stocksharp.ru/users/16691/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;p&gt;Добрый день, извините за беспокойство.
Задача следующая есть своя история full ордерлога в формате:&lt;/p&gt;
&lt;p&gt;#SYMBOL,SYSTEM,TYPE,ID,ACTION,PRICE,VOLUME,ID_DEAL,PRICE_DEAL&lt;/p&gt;
&lt;p&gt;сделки со шлюза поступают в формате:&lt;/p&gt;
&lt;p&gt;RIH3,F,B,20130111190000261,9746301221,1,164960.00000,1,0,0
RIH3,F,B,20130111190000261,9746301221,2,164960.00000,1,682802371,157370.00000
RIH3,F,S,20130111190000261,9746300660,2,157370.00000,1,682802371,157370.00000&lt;/p&gt;
&lt;p&gt;соответственно я хочу их добавить к той историии что пишет гидра.
вопрос1. RIM1@RTS.  RIM1@RTS - security.id, а security.UnderlyingSecurityId это что?&lt;/p&gt;
&lt;p&gt;вопрос2. для строчек с action = 0 || 1 trade=null и вся информация пишется в ордер в частности:
id,time,direction,state,security,price,volume. можно ли остальные поля оставлять непроинициализированные. на какие поля могут выбрасываться исключения при тестировании. например order.status?
вопрос3. несмотря на то, что security.decimal=0&lt;/p&gt;
&lt;pre&gt;&lt;code class="language-plain"&gt;
 order.Price = Decimal.Parse(Split[6], CultureInfo.InvariantCulture);

&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;естественно пишет в это поле цену со всеми нулями. как этого избежать (если не хочется в ручную сплитить цену)?&lt;/p&gt;
&lt;p&gt;вопрос4. самый важный для меня.
что делать с order в orderlogitem когда проходит сделка? если его заполнять не будет ли дубляжа прихода заявок?
я имею в виду что у нас уже есть заявка которая проинициализировала сделку от строчки
&lt;em&gt;RIH3,F,B,20130111190000261,9746301221,1,164960.00000,1,0,0&lt;/em&gt;
плюс заявка которая когда-то выставилась.&lt;/p&gt;
&lt;p&gt;и две строчки (в случае если больше одной заявки мы не снесли)
&lt;em&gt;RIH3,F,B,20130111190000261,9746301221,2,164960.00000,1,682802371,157370.00000
RIH3,F,S,20130111190000261,9746300660,2,157370.00000,1,682802371,157370.00000&lt;/em&gt;&lt;/p&gt;
&lt;p&gt;и что писать в trade.status. спасибо.&lt;/p&gt;
&lt;p&gt;как мне кажется вид обработки одной строчки будет выглядеть примерно так:&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;
string[] Split = CurrentLine.Split(',');
                   if (Split[0] == security.Id)
                   {
                       var orderlogItem = new OrderLogItem();
                       var order = new Order();
                       var trade = new Trade();
                       if (Split[5] == &amp;quot;2&amp;quot;)
                       {
                           order=null;
                           trade.Time=DateTime.ParseExact(Split[3], &amp;quot;yyyyMMddHHmmssfff&amp;quot;, CultureInfo.InvariantCulture, DateTimeStyles.None);
                           trade.OrderDirection=(Split[2] == &amp;quot;B&amp;quot; ? OrderDirections.Buy : OrderDirections.Sell);
                           trade.Security=security;
                           trade.Id=Int64.Parse(Split[8]);
                           trade.Price=Decimal.Parse(Split[9], CultureInfo.InvariantCulture);
                           trade.Volume=int.Parse(Split[7]);
                           
                       }
                       else
                       {
                           trade=null;
                           order.Time=DateTime.ParseExact(Split[3], &amp;quot;yyyyMMddHHmmssfff&amp;quot;, CultureInfo.InvariantCulture, DateTimeStyles.None);
                           order.Direction=(Split[2] == &amp;quot;B&amp;quot; ? OrderDirections.Buy : OrderDirections.Sell);
                           order.Security=security;
                           order.Id=Int64.Parse(Split[4]);
                           order.Price=Decimal.Parse(Split[6], CultureInfo.InvariantCulture);
                           order.Volume=int.Parse(Split[7]);
                           order.State = (Split[5] == &amp;quot;1&amp;quot;) ? OrderStates.Active : OrderStates.Done;
                      
                       }

                      
                       orderlogItem.Order = order;
                       orderlogItem.Trade = trade;
                       orderlogItems.Add(orderlogItem);
                   }

&lt;/code&gt;&lt;/pre&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
</feed>