Сергей Качурин (Все сообщения пользователя)

Выбрать дату в календареВыбрать дату в календаре

Страницы: 1
OnTransReply по стоп заявкам
 
Здравствуйте

Брокер ВТБ. Акции.

Почему-то не приходят OnTransReply при попытке ПОМЕНЯТЬ стоп.
То есть ставится  корректно всегда. Снимается корректно, а вот при попытке поставить сразу же новый OnTransReply не приходит и стоп не ставится.

Алгоритм такой: при входе ставим стоп -> при изменении цены удаляем стоп -> сразу же ставим новый.

Установка сейчас уже происходит так:
Ждем ответа 10 раз по 100 мл сек — ответ не пришел, значит считаем, что он негативный/или пришел негативный — идем в таблицу и 3 раза ее перебираем с небольшой паузой в поисках активного стопа по нашему инструменту — не находим, то отправляем новый !!! и вся процедура повторяется ( и так 5 раз) . На 6й раз — убиваем позицию и работаем дальше (предполагается, что без ошибок)

И все равно - ответа нет - 8 секунд !! (фото Меняем стопы)
фото 2 - бесчинства брокера (вероятно)

Как быть? Менять брокера (вроде как стоп-заявки на его сервере обрабатываются) ?
Или может быть косяк в коде (функция стопов вынесена отдельно - к ней идет просто обращение абсолютно идентичное в 1й после открытия позиции и последующие разы) ?

Прошу совета профессионалов.

.
"Засыпание" скриптов, Имею три работающих скрипта на Lua, которые периодически (раз в пару дней кто-нибудь из них точно) "засыпают"
 
Sergey Denegin, хотя, это, наверное, единственное разумное объяснение..

Не знаете какая пауза должна быть в соединении, чтобы is_connected показало false ?
"Засыпание" скриптов, Имею три работающих скрипта на Lua, которые периодически (раз в пару дней кто-нибудь из них точно) "засыпают"
 
Возможно, но вероятность не очень велика..
20 попыток в течение секунды есть у скрипта.. Да и закрытие дня проходит без опозданий.

Возможно периодическое "подвисание" терминала на несколько секунд? Это бы объяснило ошибки с перестановкой и снятием стопов..

как с этим принято бороться?
"Засыпание" скриптов, Имею три работающих скрипта на Lua, которые периодически (раз в пару дней кто-нибудь из них точно) "засыпают"
 
Здравствуйте!

Имею три работающих скрипта на Lua, которые периодически (раз в пару дней кто-нибудь из них точно) "засыпают" - перестают выдавать проверочные сообщения, но на другие "раздражители" реагируют. (фото 2 - нормальная работа, фото 1 - "засыпание")

Основная проблема в том, что, если сделка случается в таком состоянии скрипта, она всегда заканчивается кучей сообщений с ошибками (типа:  Не могу снять стоп-заявку. Пришел статус 4. и подобными). Хотя в нормальном состоянии скрипта сделки проходят корректно.

Сам скрипт достаточно большой - вот самое парадоксальное место: как видно на фото скрипт игнорирует сообщение каждые 15 минут, но реагирует на закрытие торгового дня !

обе функции так и стоят рядом, в корне основного потока. Ни на какие дополнительные условия не завязаны.



Буду признателен за любую помощь в решении этой загадки
Код
--===============================================
 
   if Here == 0 then  --- сообщение каждые 15 минут. с запомнеными параметрами 
      Here = math.floor(os.clock())
      
   elseif math.floor(os.clock()) == Here + 900 then 
      Here = math.floor(os.clock())
      message ("SBER. I`m here! every 15 min", 1)
      
      message("StartUP - "..tostring(StartUP), 1)
      message("tp[0].open - "..tostring(tp[0].open), 1)
      
      message("StartDOWN - "..tostring(StartDOWN), 1)
      sleep(50)
      
   end
--===============================================   
-- проверка TIME
   local Time = integer
   dt = os.date()        -- системная функция времени/даты
    ddt = string.sub(dt, 10, 14)    -- берем нужные графы
    if ddt == "18:44" then Time = 1      -- тут ставим время выхода из позиций LastOpenBarIndex = DS:Size()
      while Time == 1 do
         to_log("trade day ends ".." close "..tostring(count).." lot(s)")
         message ("SBER trade day ends ".." close "..tostring(count).." lot(s)",1)
         if count > 0 then
            Trade("S",count,lastPrice-p_spread) 
            count = 0
            stv.SetVar("count", 0) 
            if SP == 1 then
               Rem_ST_TP(ST_orderNum)
            end
         end   
         if count < 0 then
            Trade("B",math.abs(count),lastPrice+p_spread)
            count = 0
            stv.SetVar("count", 0) 
            if SP == 1 then
               Rem_ST_TP(ST_orderNum)
            end
         end
         Time = 0
         sleep(900000)  -- 15 минут спим,чтобы недопустить вход до конца торг. сессии
      end
   elseif ddt == "10:00" then
      LastOpenBarIndex = DS:Size()
   end   
Не работает OnAccountBalance
 
перешел с фьючерсов на акции
перестал работать  OnFuturesClientHolding
хотел заменить на OnAccountBalance , но он не работает

Посоветуйте решение, пожалуйста. Sergey Gorokhov,
Не работает OnAccountBalance
 
а "текущие" - только Торги
Не работает OnAccountBalance
 
не получается прикрепить скрин, но такой таблицы нет.. Даже по слову "текущих" - пустой экран
Не работает OnAccountBalance
 
[img]file:///C:/Users/%D0%A1%D0%B5%D1%80%D0%B3%D0%B5%D0%B9/Downloads/%D0%A1%D0%BD%D0%B8%D0%BC%D0%BE%D0%BA.JPG[/img][img]file:///C:/Users/%D0%A1%D0%B5%D1%80%D0%B3%D0%B5%D0%B9/Downloads/%D0%A1%D0%BD%D0%B8%D0%BC%D0%BE%D0%BA.JPG[/img]Sergey Gorokhov, вот прямо так и называется? "Таблица текущих позиций по счетам"  
Не работает OnAccountBalance
 
Цитата
Sergey Gorokhov написал:
Эта таблица находится в меню Дилер / Текущие позиции по счетам...

Соответственно, если у Вас нет такого меню, или ест?ь но в нем данная таблица пустая, то и колбек срабатывать не должен.
Sergey Gorokhov, где найти эту волшебную таблицу? Версия 7.0.4.10
BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Sergey Gorokhov, спасибо! Всё заработало.

что это за строчка такая, если не секрет?
BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Sergey Gorokhov,
вот так расчет пошел - for i=1,ds:Size() do

результат в таблице:
Код
   Price            SROC
1   91360   
2   91330   
3   91310   
4   91310   
5   91280   
6   91270   
7   91310          99,955126281672
и снова  C:\FinamJunior\LuaIndicators\SROC.lua:110: attempt to perform arithmetic on field '?' (a nil value)

код:
Код
for x = 2,4 do --periods
         func = SROC()
         t_id = AllocTable()
         AddColumn(t_id,1,"Price",true,QTABLE_INT_TYPE,10)
         AddColumn(t_id,2,"SROC",true,QTABLE_INT_TYPE,10)
         CreateWindow(t_id)
         SetWindowCaption(t_id,"SROC")
         message("2", 1)
         ds = CreateDataSource("SPBFUT", "RIU6", INTERVAL_M1) 
         sleep(100)

for i=1,ds:Size() do --candels
         message("4", 1)
         ma_out=func(i, {Period = x, Metod = "EMA", VType="Close", round="off"}, ds)
         tmp=InsertRow(t_id,-1)
         SetCell(t_id,tmp,1,tostring(ds:C(i)),ds:C(i))
         SetCell(t_id,tmp,2,tostring(ma_out),ma_out)
         message("5", 1)
            
         if i > 4+x then
            y = func(i-2, {Period = x, Metod = "EMA", VType="Close", round="off"}, ds) 
            y1 = func(i-1, {Period = x, Metod = "EMA", VType="Close", round="off"}, ds) 
            y2 = func(i, {Period = x, Metod = "EMA", VType="Close", round="off"}, ds)
            message("6", 1)
            
            if count == 0
ошибка между message "5" и message "6" ...
BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Sergey Gorokhov,  не подскажете в чем может быть засада?


C:\FinamJunior\LuaIndicators\SROC.lua:110: attempt to perform arithmetic on field '?' (a nil value)  

Если вместо SROC звать МА, то ошибка на 83 строке.
Код
for x = 2,4 do --periods
      func = SROC()
      t_id = AllocTable()
      AddColumn(t_id,1,"Price",true,QTABLE_INT_TYPE,10)
   AddColumn(t_id,2,"SROC",true,QTABLE_INT_TYPE,10)
   CreateWindow(t_id)
   SetWindowCaption(t_id,"SROC")
   ds = CreateDataSource("SPBFUT", "RIU6", INTERVAL_M1) 

   for i=1+x,ds:Size() do --candels
         
   ma_out=func(i, {Period = x, Metod = "EMA", VType="Close", round="off"}, ds) --ОШИБКА
   tmp=InsertRow(t_id,-1)
   SetCell(t_id,tmp,1,tostring(ds:C(i)),ds:C(i))
   SetCell(t_id,tmp,2,tostring(ma_out),ma_out)
            

BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Sergey Gorokhov, а как тогда обратиться к значениям каждой конкретной свечи из диапазона i=1+x,ds:Size() ?

чтобы получить вот эти значения:
Код
if i > 4+x and ma_out[i-1] > ma_out[i-2] and ma_out[i] < ma_out[i-1]

Создать таблицу (где?) в которую сохранять № свечи и значение, а потом обращаться к этой таблице?

Вы, наверное, уже видите, что задача перебрать несколько периодов индикатора и на каждом периоде проверить выполнение условий на всем диапазоне i=1+x,ds:Size() ..
BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Sergey Gorokhov, a можно к созданному индикатору присвоить идентификатор через Lua (сразу при добавлении), чтобы потом обращаться к его значениям через getNumCandles и getCandlesByIndex?

или вот такое обращение будет корректным: ma_out[i], ma_out[i-1]... ?
Код
for i=1+x,ds:Size() do
   ma_out=func(i, {Period = x, Metod = "EMA", VType="Close", round="off"}, ds)
   tmp=InsertRow(t_id,-1)
   SetCell(t_id,tmp,1,tostring(ds:C(i)),ds:C(i))
   SetCell(t_id,tmp,2,tostring(ma_out),ma_out)
            
   if i > 4+x and ma_out[i-1] > ma_out[i-2] and ma_out[i] < ma_out[i-1]
end 
BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Sergey Gorokhov,
а не подскажете как убрать вот эту ошибку: C:\FinamJunior\LuaIndicators\_Line.lua:27: attempt to perform arithmetic on a nil value. Выскакивает по количеству периодов расчета

такой вариант не помог
Код
if func1 ~= nil and func2 ~= nil then
   return (func1(Index, Settings)+func2(Index, Settings))/2
end
BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Sergey Gorokhov, спасибо , всё работает!
BULLS & BEARS, как получить линию разности быков и медведей с помощью индикаторов на Луа
 
Здравствуйте.

Пытаюсь слегка изменить выложенные разработчиком индикаторы: получить Линию разности Быков и Медведей..
Соединил их вместе:

Думал, BULLS() возвращает значение (но если tostring, то печатает "function: F028E025" - примерно, tonumber - nil).

Предположил, что значение сидит в Out (func = Out1- Out2), но выходит nil, а дальше ошибка, что ожидается число..Вроде логично, ведь период 13 и первые 12 значений скорее всего пустые.
Убрал под if Out1~=nil and Out2~=nil .. и вот тут началось самое интересное - индикатор просто пропал из списка доступных индикаторов!
Возможно, это встроенная защита от ошибок ..
Джуниор 7.0.0.289

Подскажите, пожалуйста, начинающему в чём ошибка.

Код
Settings = {
Name = "*line_1", 
round = "off",
Period = 13, 
Metod = "EMA", --SMA, EMA, VMA, SMMA, VMA 
VType = "Close", --Open, High, Low, Close, Volume, Median, Typical, Weighted, Difference 
line = {
      Name = "LINE", 
      Type = TYPE_LINE, 
      Color = RGB(255, 0, 0)
      }
}
   
function Init() 
   func1 = BULLS()
   func2 = BEARS()
   message (tostring(Out1), 1)
   if Out1~=nil and Out2~=nil
      func = Out1- Out2
   end
   return #Settings.line
end

function OnCalculate(Index) 
   return func1(Index, Settings) and func2(Index, Settings)
end

function BULLS() --Bulls Power ("BULLS")
   local Bulls_MA=MA()
return function (I, Fsettings, ds)
local Out1 = nil
local Fsettings=(Fsettings or {})
local P = (Fsettings.Period or 13)
local M = (Fsettings.Metod or "EMA")
local VT = (Fsettings.VType or "Close")
local R = (Fsettings.round or "off")
local b_ma = Bulls_MA(I, {Period=P, Metod = M, VType=VT, round=R}, ds)
if I>=P and b_ma then
   Out1 = Value(I, "High", ds)-b_ma
else Out1 = b_ma end
   return rounding(Out1, R),0
end
end

function BEARS() --Bears Power ("BEARS")
   local Bears_MA=MA()
return function (I, Fsettings, ds)
local Out2 = nil
local Fsettings=(Fsettings or {})
local P = (Fsettings.Period or 13)
local M = (Fsettings.Metod or "EMA")
local VT = (Fsettings.VType or "Close")
local R = (Fsettings.round or "off")
local b_ma = 0

b_ma=Bears_MA(I, {Period=P, Metod = M, VType=VT, round=R}, ds)
if I>=P and b_ma then
   Out2 = Value(I, "Low", ds)-b_ma
else Out2 = b_ma end
   return rounding(Out2, R),0
end
end

function MA() --Moving Average ("MA")
local t_SMA = F_SMA()
local t_EMA = F_EMA()
local t_VMA = F_VMA()
local t_SMMA = F_SMMA()
local t_WMA = F_WMA()
return function(I, Fsettings, ds)
   local Out = nil
   local Fsettings=(Fsettings or {})
   local P = (Fsettings.Period or 9)
   local M = (Fsettings.Metod or "EMA")
   local VT = (Fsettings.VType or "Close")
   local R = (Fsettings.round or "off")
   if M == "SMA" then
      Out = t_SMA(I, P, VT, ds, R)
   elseif M == "EMA" then
      Out = t_EMA(I, P, VT, ds, R)
   elseif M == "VMA" then
      Out = t_VMA(I, P, VT, ds, R)
   elseif M == "SMMA" then
      Out = t_SMMA(I, P, VT, ds, R)
   elseif M == "WMA" then
      Out = t_WMA(I, P, VT, ds, R)
   else
      Out = nil
   end
   return rounding(Out, R)
end
end
------------------------------------------------------------------
--Moving Average SMA, EMA, VMA, SMMA, VMA
------------------------------------------------------------------
--[[Simple Moving Average (SMA)
SMA = sum(Pi) / n
]]
function F_SMA()
return function (I, Period, VType, ds, round) 
local Out = nil
   if I >= Period then
      local sum = 0
      for i = I-Period+1, I do
         sum = sum +Value(i, VType, ds)
      end
      Out = sum/Period
   end 
   return rounding(Out,round)
end
end

--[[Exponential Moving Average (EMA)
EMAi = (EMAi-1*(n-1)+2*Pi) / (n+1)
]]
function F_EMA() 
local EMA_TMP={}
return function(I, Period, VType, ds, round)
local Out = nil
   if I == 1 then
      EMA_TMP[I]=rounding(Value(I, VType, ds),round)
   else
      EMA_TMP[I]=rounding((EMA_TMP[I-1]*(Period-1)+2*Value(I, VType, ds)) / (Period+1),round)
      EMA_TMP[I-2]=nil
   end
   
   if I >= Period then
      Out = EMA_TMP[I]
   end
   return rounding(Out,round)
end
end

--[[
William Moving Average (WMA)
( Previous WILLMA * ( Period - 1 ) + Data ) / Period
]]
function F_WMA()
   local WMA_TMP={}
return function(I, Period, VType, ds, round)
local Out = nil
   if I == 1 then
      WMA_TMP[I]=rounding(Value(I, VType, ds),round)
   else
      WMA_TMP[I]=rounding((WMA_TMP[I-1]*(Period-1)+Value(I, VType, ds)) / Period,round)
     WMA_TMP[I-2]=nil
   end
   if I >= Period then
      Out = WMA_TMP[I]
   end
   return rounding(Out,round)
end
end

--[[Volume Adjusted Moving Average (VMA)
VMA = sum(Pi*Vi) / sum(Vi)
]]
function F_VMA()
return function (I, Period, VType, ds, round)
local Out = nil
   if I >= Period then
      local sum = 0
      local sumV = 0
      for i = I-Period+1, I do
         sum = sum +Value(i, VType, ds)*Value(i, "Volume", ds)
         sumV = sumV +Value(i, "Volume", ds)
      end
      Out = sum/sumV
   end
   return rounding(Out,round)
end
end

--[[Smoothed Moving Average (SMMA)
SMMAi = (sum(Pi) - SMMAi-1 + Pi) / n
]]
function F_SMMA()
local SMMA_TMP={}
return function(I, Period, VType, ds, round)
local Out = nil
   if I >= Period then
      local sum = 0
      for i = I-Period+1, I do
         sum = sum +Value(i, VType, ds)
      end
      
      if I == Period then
         SMMA_TMP[I]=rounding((sum-Value(I, VType, ds)+Value(I, VType, ds)) / Period, round)
      else
         SMMA_TMP[I]=rounding((sum-SMMA_TMP[I-1]+Value(I, VType, ds)) / Period, round)
      end
      SMMA_TMP[I-2]=nil
      Out = SMMA_TMP[I]
   end
   return rounding(Out,round)
end
end


function rounding(num, round) 
if round and string.upper(round)== "ON" then round=0 end
if num and tonumber(round) then
   local mult = 10^round
   if num >= 0 then return math.floor(num * mult + 0.5) / mult
   else return math.ceil(num * mult - 0.5) / mult end
else return num end
end

function Value(I,VType,ds) 
local Out = nil
VType=(VType and string.upper(string.sub(VType,1,1))) or "A"
   if VType == "O" then      --Open
      Out = (O and O(I)) or (ds and ds:O(I))
   elseif VType == "H" then    --High
      Out = (H and H(I)) or (ds and ds:H(I))
   elseif VType == "L" then   --Low
      Out = (L and L(I)) or (ds and ds:L(I))
   elseif VType == "C" then   --Close
      Out = (C and C(I)) or (ds and ds:C(I))
   elseif VType == "V" then   --Volume
      Out = (V and V(I)) or (ds and ds:V(I)) 
   elseif VType == "M" then   --Median
      Out = ((Value(I,"H",ds) + Value(I,"L",ds)) / 2)
   elseif VType == "T" then   --Typical
      Out = ((Value(I,"M",ds) * 2 + Value(I,"C",ds))/3)
   elseif VType == "W" then   --Weighted
      Out = ((Value(I,"T",ds) * 3 + Value(I,"O",ds))/4) 
   elseif VType == "D" then   --Difference
      Out = (Value(I,"H",ds) - Value(I,"L",ds))
   elseif VType == "A" then   --Any
      if ds then Out = ds[I] else Out = nil end
   end
return Out
end
Снятие стоп-заявок, ответ на транзакцию
 
Победить решил проверкой Флага на стоп-заявке, после получения ошибки снятия.

Но был бы крайне признателен, если кто-нибудь хотя бы намекнул почему возможна ситуация, описанная выше...  
Снятие стоп-заявок, ответ на транзакцию
 
снимаю стоп-заявку по номеру  - примерно каждый 4й -5й раз приходит Статус "4", но заявка снимается. Причем сразу после сообщения о снятии заявки.. Не могу понять как с этим бороться.
Код
-- СНИМАЕМ СТОПЫ 
function Rem_ST_TP(ST_orderNum)
   trans_id = trans_id + 1
   message("2 ST_orderNum"..ST_orderNum, 1)
   local transaction={
                    ["TRANS_ID"] = tostring(trans_id),
                    ["ACTION"] = "KILL_STOP_ORDER",
                    ["CLASSCODE"] = p_classcode,
                    ["SECCODE"] = p_seccode,
               ["STOP_ORDER_KEY"] = tostring(ST_orderNum+0),
               ["COMMENT"]             = "ТЭЙК-ПРОФИТ и СТОП-ЛОСС"   
   }
    local res=sendTransaction(transaction)
   message ("res "..tostring(res), 1)   
   while is_run and trans_Status == nil do 
      sleep(10);
   end;
    
   -- Запоминает значение
    local Status = trans_Status;
   -- Очищает глобальную переменную
    trans_Status = nil;
    -- Если транзакция не выполнена по какой-то причине
   if Status ~= 3 then
      -- Выводит сообщение с ошибкой
      message("Status ~= 3: "..tostring(Status) ..". Снятие ПРОФИТ-ЛОСС не удалось!\nОШИБКА: "..trans_result_msg);
     
      -- Возвращает FALSE
      -- return false;
   else
      -- Выводит сообщение
      message('Снят ТЭЙК & ЛОСС: '..trans_id);
      OrderNum_CLOSE = nil;
     SP = 0
     ST_orderNum = nil
   end;
   
end
Вот такие сообщения приходят: в порядке поступления - сверху вниз

14:22:01  2 ST_orderNum"..ST_orderNum
14:22:01
14:22:01 Стоп-заявка с № [ST_orderNum] снята.
14:22:01 Не удается снять стоп-заявку № [ST_orderNum].
14:22:01 Status ~= 3: 4. Снятие ПРОФИТ-ЛОСС не удалось! ОШИБКА: Не удается снять стоп-заявку № [ST_orderNum].

Получается, что OnTransReply отвечает мне дважды на один и тот же запрос?...но запрос то один..

Расскажите, пожалуйста, как это победить и как работает логика ответа на транзакции в  Quik ?
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Николай Камынин, спасибо! Ваше предположение также оказалось верным: Обнулял переменную в ненужном месте..  а ошибка с 6-ю нулями была получена до того как вставил обнуление переменной.
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Sergey Gorokhov, спасибо, действительно даже 1й вариант оказался рабочим - ["STOP_ORDER_KEY"] = tostring(ST_orderNum+0)

нашел место, где ST_orderNum присваивал nil...  
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Николай Камынин, сравнение работает. Переменная глобальная.

Думать, что в ней ничего нет - не получается ввиду вот таких сообщений об ошибке: "Неправильно указан номер заявки: "1314760.000000"
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Sergey Gorokhov,

сравнение работает

Выдает же либо "Неправильно указан номер заявки: "1314760.000000" - если ввод через tonumber
либо "Неправильно указан номер заявки: "nil" - если ввод через tostring


вот trans_id пишет и ST_orderNum -   без нулей
Код
if stop_order.trans_id == trans_id then
   ST_orderNum = stop_order.order_num  -- сохраняем номер
   message("ST_orderNum"..ST_orderNum, 1)
   break
end;
при вводе через tonumber - цифра правильная, но вот эти шесть нулей победить не удается  
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
[USER=17]Sergey Gorokhov ,Николай  Камынин[/USER], в том то и дело что сравнение работает

Выдает же либо "Неправильно указан номер заявки: "1314760.000000"  - если ввод через tonumber
либо  "Неправильно указан номер заявки: "nil" - если ввод через tostring


вот trans_id пишет и ST_orderNum.
[img][/img]

при вводе через tonumber - цифра правильная, но вот эти шесть нулей победить не удается
[img][/img]
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Sergey Gorokhov, вот даже так попробовал сейчас

ST_orderNum = tonumber(ST_orderNum)  и потом

["STOP_ORDER_KEY"] = string.format("%.0f", ST_orderNum)

и все равно: bad argument #2 to 'format' (number expected, got nil)
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Sergey Gorokhov,  получается, что приходит Строка, которую потом надо преобразовать в Номер, а затем снова в Строку?

странно, что не проходит простой вариант ["STOP_ORDER_KEY"] = ST_orderNum
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Получаю номер стоп заявки из таблицы.
Код
while is_run and ST_orderNum == nil do -- перебираем таблицу Стопов
         for i=0,getNumberOf("stop_orders")-1 do
            local stop_order = getItem("stop_orders", i);
            
            -- Если заявка по текущей транзакции СТОП-ЛОСС и ТЭЙК-ПРОФИТ
            if stop_order.trans_id == trans_id then
               ST_orderNum = stop_order.order_num  -- сохраняем номер
               message("ST_orderNum"..ST_orderNum, 1)
               break
            end;
         end;
         sleep(10)
end
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Цитата
Sergey Gorokhov написал:
еще можно вот так:
["STOP_ORDER_KEY"] = string.format("%.0f", ST_orderNum)
этот вариант дает bad argument #2 to 'format' (number expected, got nil)
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Цитата
Sergey Gorokhov написал:
Здравствуйте,
Номер должен быть в виде строки и без нулей.
["STOP_ORDER_KEY"] = "1314760"

к слову tostring("1314760.0000000") вернет "1314760.0000000" (не правильно)
а tostring(1314760.0000000) вернет "1314760" (правильно)

попробуйте добавить +0 в параметре функции tostring
["STOP_ORDER_KEY"] = tostring(ST_orderNum+0)
Sergey Gorokhov,   вариант ["STOP_ORDER_KEY"] = tostring(ST_orderNum+0) возвращает "attempt to perform arithmetic on local 'ST_orderNum' (a nil value)"
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
tonumber(ST_orderNum) , конечно тоже пробовал
Значение поля "номер стоп-заявки", Выдает ошибку всеми возможными способами
 
Получаю номер стоп заявки из таблицы и пытаюсь ее снять через ["STOP_ORDER_KEY"]
получаю ошибку или "не указано значение поля" - если вводить сразу полученную переменную = ST_orderNum
либо "Неправильно указан номер заявки: "1314760.000000" - если вводить через функции

перепробовано уже:
math.floor(ST_orderNum)
tostring(ST_orderNum)
math.abs(ST_orderNum)

Каким же должен быть формат данного поля?
Обращение к конкретному окну Quik и конкретной вкладке
 
Sergey Gorokhov, ок.

к Окну можно обратиться и через командную строку, например..

А по Вкладкам внутри Окна можно как-то переходить?  
Обращение к конкретному окну Quik и конкретной вкладке
 
 скрипты на  Lua, если это имеет значение..
Обращение к конкретному окну Quik и конкретной вкладке
 
Здравствуйте!

1. Возможно ли обращение к конкретному окну программы, если запущено более одного экземпляра? (действие -  развернуть на весь экран)

2. Возможно ли обращение к конкретной вкладке внутри окна? (действие -  развернуть на весь экран, то есть перейти на нее)

Скрипт делает скрин экрана по событию, было бы крайне удобно при работе несколькими скриптами скринить именно нужную вкладку в нужном экземпляре программы.
Версия 7.2 - Идентификаторы, Изменились поля идентификаторов
 
Zoya Skvorcova, здравствуйте!

а когда (примерно) ожидать?

Чтобы понять стоит ли заново инсталлировать версию 7.0 или ждать обновления..
Версия 7.2 - Идентификаторы, Изменились поля идентификаторов
 
В версии 7.0 у каждого индикатора было своё (независимое, уникальное) поле Идентификатор. Данное поле позволяло скрипту однозначно идентифицировать получаемую информацию.
В версии 7.2, устанавливая идентификатор к любому Графику любого Инструмента, я получаю сквозную установку данного идентификатора для данного типа Графика на всех Инструментах.

Пример в скринах. Ставлю идентификатор к Прайс на Br - такой же выскакивает на всех Инструментах..

Как взять данные Прайс Br и Si, например. И быть уверенным, что это данные именно с этих Инструментов?
Страницы: 1
Наверх