Прошу помочь исправить ошибку в коде

Страницы: 1
RSS
Прошу помочь исправить ошибку в коде, Скрипт при запуске в QUIK выдаёт ошибку: "18: attempt to index a nil value (global 'ds')"
 
Здравствуйте.
Прошу помочь устранить ошибку в коде скрипта. Скрипт при запуске в QUIK выдаёт ошибку: "18: attempt to index a nil value (global 'ds')".
Вот код скрипта:

-- переменная для прырывания цикла при срабатывании функции обратного вызова OnStop

is_run = true

-- присванивание переменным начальных базовых значений торгового алгоритма

Account = "L01-00000F00"     -- торговый счет
Class_Code = "QJSIM"         -- класс торгуемого инструмента
Sec_Code = "SBERP"            -- код торгуемого инструмента
TF = INTERVAL_D1             -- торговый таймфрейм
g_lots = 1                   -- количество торгуемых лот

function main()
   -- подписываемся на получение данных свечей по инструменту в массив ds
   ds=CreateDataSource (Class_Code, Sec_Code, TF )
   while is_run do
         sleep(1000)            -- обрабатываем цикл с задержкой 1сек.
         ds:SetEmptyCallback()  -- обновляем данные по инструменту в массиве ds
         
         
         
         local serv_time=tonumber(timeformat(getInfoParam("SERVERTIME"))) -- помещене в переменную времени сервера в формате HHMMSS                  
         if isConnected()==1 and serv_time>=10000 and serv_time<235000 then -- проверка наличия соеденения с сервером и поподания в торговое окно
            -- место для размещения торговой логики
            -- расчет значения скользящей средней
            local SMA = 0
            local period = 20
            local count_candle = ds:size()
            if count_candle>20 then
               local sum = 0
               for i=0 , period-1 do                                                  
                   sum = sum + ds:C(count_candle-i)
               end
               SMA = sum / period
               local lots = get_lots()            

               -- получение количества лот в клиентском портфеле по инструменту
               if ds:C(count_candle)>SMA and lots<g_lots then
                   -- получение минимального шага цены для организации величины проскальзываня в ордере
                   local step=tonumber(getParamEx(Class_Code, Sec_Code, "SEC_PRICE_STEP").param_value)
                   local price_order = ds:C(count_candle)+(step*20)
                   -- цена для ордера будет = цена закрытия + 20-ть минимальных шагов инст.
                   send_order("B", math.abs(g_lots-lots) , price_order)
               end
               if ds:C(count_candle)<SMA and lots>(g_lots*(-1)) then
                   -- получение минимального шага цены для организации величины проскальзываня в ордере
                   local step=tonumber(getParamEx(Class_Code, Sec_Code, "SEC_PRICE_STEP").param_value)
                   local price_order = ds:C(count_candle)-(step*20)    
                   -- цена для ордера будет = цена закрытия - 20-ть минимальных шагов инст.
                   send_order("S", math.abs(g_lots+lots) , price_order)
               end
            end                  
          end
   end
end

-- функция возвращает количество лот в клиентском портфеле по заданному инструменту
function get_lots()
   local lots = 0
   local n = getNumberOf("futures_client_holding")
   local futures_client_holding={}                    
   for i=0,n-1 do            
      futures_client_holding = getItem("futures_client_holding", i)
      if tostring(futures_client_holding["sec_code"])==Sec_Code then
         lots=tonumber(futures_client_holding["totalnet"])
      end
   end      
   return lots
end
----------------------

-- отправка транзакции
function send_order(operation, quantity, price)      
   -- получение минимального шага цены для округления цены отправляемого ордера
   local step=tonumber(getParamEx(Class_Code, Sec_Code, "SEC_PRICE_STEP").param_value)
   local trans_params =
         {
           CLIENT_CODE = Account,
           CLASSCODE = Class_Code,
           SECCODE = Sec_Code,
           ACCOUNT = Account,
           TYPE = "L",
           TRANS_ID = tostring(1),
           OPERATION = tostring(operation),
           QUANTITY = tostring(math.abs(quantity)),
           PRICE = tostring(math.floor(tonumber(price)/step)*step),  -- округление цены при отправлении транзакции
           ACTION = "NEW_ORDER"
         }
   local res = sendTransaction(trans_params)
   if string.len(res) ~= 0 then
       message('Error: '..res,3)
       return 0
   else
       return trans_id
   end      
end

function OnStop(stop_flag)              
    is_run=false
    stop_flag=1
    ds:Close()
end


function timeformat(time_unf)
    local in1, in2=0,0
    local time_form=0      
    in1=string.find(time_unf,":" , 0)
    if in1~=nil and in1~=0 then
       in2=string.find(time_unf,":" , in1+1)
       time_form=string.sub(time_unf, 0 ,in1-1)..string.sub(time_unf, in1+1 ,in2-1)..string.sub(time_unf, in2+1 ,string.len(time_unf))
    end
    return time_form
end
 
Цитата
Алексей написал:
Class_Code = "QJSIM"         -- класс торгуемого инструмента

точно ли код класса указан верно?
Такой класс есть только на нашем демо контуре, у брокеров нужно указать TQBR
 
Цитата
Sergey Gorokhov написал:
Цитата
Алексей написал:
Class_Code = "QJSIM"         -- класс торгуемого инструмента

точно ли код класса указан верно?
Такой класс есть только на нашем демо контуре, у брокеров нужно указать TQBR
Спасибо. Действительно, код класса исправил и всё заработало.
Страницы: 1
Читают тему (гостей: 1)
Наверх