Дмитрий (Все сообщения пользователя)

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

Страницы: 1
Работа нескольких скриптов с одним файлом, Выдает периодически ошибку при работе нескольких скриптов с одним файлом
 
Hазобрался, настроил, вроде работает как надо. спасибо.
Последний вопрос для закрепления материала )))
а вот эта запись " Log:flush() " - что означает в вашем примере записи в Log ?
Работа нескольких скриптов с одним файлом, Выдает периодически ошибку при работе нескольких скриптов с одним файлом
 
Цитата
nikolz написал:
У меня один лог файл. В него пишут разные потоки. Так как я могу создавать любое число потоков и Lua машин, то мне нет надобности создавать еще какие-то скрипты.  Но мой вариант работы эквивалентен вашему варианту с двумя скриптами.У меня проблемы запись в этот  файл.  Попробуйте открывать файлы один раз с дозаписью и завершать запись принудительной записью в файл.типа так: Log:write(os.date()..","..tostring(s)..",num="..tostring(num)..","..tostring(count).."\n"); Log:flush();
Вот это, наверное, то, что нужно, только я не понял всю конструкцию - как открыть один раз и потом дописывать? т.е. просто у вас один раз в начале открыт Log = io.open('...', 'a'), а потом уже без открытия просто по ходу вставляете Log:write(os.date()..' и так дает дописывать?
p.s. я кажется свою проблему понял, у меня не второй скрипт конфликтил с первым, у меня в первом колбеки могли при стечении обстоятельств писать "логи" одновременно с main(), а так как я постоянно "io.open" и "close' при каждой записи - получалась коллизия, а если буду держать файл открытым, то будут писать оба без ругани, получается. Так?
Работа нескольких скриптов с одним файлом, Выдает периодически ошибку при работе нескольких скриптов с одним файлом
 
В моей ситуации, я так понимаю, это не поможет. У меня 2 скрипта иногда открывают один и тот же файл (мне надо иметь общий файл, а одновременное открытие - совпадение, которое
надо как-то нейтрально обходить), а потом кто-то его первый закрывает, а второй при попытке закрыть еще раз выдает ошибку. Я так это вижу исходя из того, что именно на FileWrite:close() в первом скрипте происходит ошибка (во втором скрипте открывает на чтение и отрабатывает быстрее - там никогда ошибку не выдает - я там вообще только первую строку читаю, больше не надо).
Отсюда вопрос: а как-то статус, что файл стал "close" можно получить запросом? пытался выводить значение переменной "FileWrite" через "tostring", чтоб по нему как-то зацепиться, но выдает какой-то буквенно-цифровой код, описание структуры которого в инете найти не смог.
Работа нескольких скриптов с одним файлом, Выдает периодически ошибку при работе нескольких скриптов с одним файлом
 
"либо писать метку в строку и искать эту метку" - а это как работает?
Работа нескольких скриптов с одним файлом, Выдает периодически ошибку при работе нескольких скриптов с одним файлом
 
И что-то такая конструкция работает не правильно, теперь у меня файл до остановки скрипта пустой. Наверное, скрипт держит его открытым и не фиксирует запись.
Работа нескольких скриптов с одним файлом, Выдает периодически ошибку при работе нескольких скриптов с одним файлом
 
Спасибо. А вы не могли бы в 2-х словах пояснить как работает условие без значения, ну т.е. я понимаю когда, например " if Filewrite == nil then ... ", а что значит переменная без сравнения в  конструкции " if Filewrite then ..." ?  
Работа нескольких скриптов с одним файлом, Выдает периодически ошибку при работе нескольких скриптов с одним файлом
 
function mark_Fail (zap, mark) - моя функция записи в файл
FileWrite = io.open('D:\\QLUA\\fails\\mark.txt', zap)
FileWrite:write(mark)
FileWrite:close()
end
а другой скрипт читает этот файл.
Все работает нормально, но периодически первый скрипт выходит на ошибку "attempt to use a closed file" на строке FileWrite:close(). Ошибка выходит редко, 2-3 раза в день, при этом запись в файл примерно каждые 6-8 секунд, а просмотр другим скриптом каждые 60 секунд)
Я своим скудным умишком полагаю, что происходит наложение запросов двух скриптов на один файл и конфликт.
Вопросы:
1) как сделать "бесшовную" работу нескольких скриптов с одним файлом? Не запись одновременно, а один скрипт пишет - несколько читают и не мешают основному писать.
2) на крайняк, как сделать, чтоб не останавливало скрипт по такой ошибке? Готов просто пропускать запись, если вдруг прошло "наложение" в этот момент
Заранее благодарю отозвавшихся на вопрос.
Номер строки в коде скрипта, Вывести номер строки в коде скрипта
 
Скрипт имеет длинный код (пишу плохо, поэтому структура кода не оптимальна), по ходу коду навставлял "ловушки", которые записывают в файл ключевые данные по работе скрипта. Потом разбираю записи и долго ищу в какой строке кода сработала запись. Вопрос - можно ли как-то вывести строку кода при реализации скрипта? Ну, типа:
message (CodeLine)
выдает сообщение с номером строки кода, где CodeLine - функция определения строки кода скрипта.
Кол-во в заявках стакана на одном ценовом уровне, Кол-во в заявках стакана на одном ценовом уровне
 
Спасибо
Кол-во в заявках стакана на одном ценовом уровне, Кол-во в заявках стакана на одном ценовом уровне
 
Понял. А в данном случае выдаст именно суммарное кол-во в лучшем спросе/предложении?  
Кол-во в заявках стакана на одном ценовом уровне, Кол-во в заявках стакана на одном ценовом уровне
 
Извиняюсь, я что такое TTT ?
Кол-во в заявках стакана на одном ценовом уровне, Кол-во в заявках стакана на одном ценовом уровне
 
Добрый день.
Скрипт:
 StKot = getQuoteLevel2 ('SPBFUT', 'CRM3')
 Q = tonumber (StKot.offer[1].quantity)
В данном случае выдаст сумму всех заявок по лучшему предложению в стакане, или если на данном уровне несколько заявок - выдаст только одну (первую в очереди) ?
Например на уровне 10,987р размещено 3 заявки по 5, 1 и 3 лота соответственно. В стакане вижу 9 лотов суммарно на этом уровне, а что выдаст указанная мной ранее функция? 5 или 9?
Заранее благодарен за помощь.
Ошибка attempt to perform arithmetic on a table value, Ошибка attempt to perform arithmetic on a table value - что значит?
 
Не могу нигде найти описание ошибки "attempt to perform arithmetic on a table value" - в переводе "попытка выполнить арифметику над табличным значением". Ну а почему нельзя выполнить арифметику над табличным значением? Или что имеется ввиду?
Работа со стаканом котировок, Кол-во строк в таблицах стакана
 
понял, спасибо
Работа со стаканом котировок, Кол-во строк в таблицах стакана
 
а проверка на nil зачем? разве могут быть в стакане значения с ценой и кол-вом, равным "ничего"?
Работа со стаканом котировок, Кол-во строк в таблицах стакана
 
я ж написал, что понял, что строки в bid идут обратной нумерацией. но все равно спасибо за ответ, глядя на вашу визуализацию, я сообразил, что система не воспринимала  NumBid = StKot.bid_count как число (а когда вычитаешь что-то - сама преобразует в число, интересно), поэтому правильно надо было NumBid = tonumber (StKot.bid_count) и все поехало.
Работа со стаканом котировок, Кол-во строк в таблицах стакана
 
Прочитал внимательно, что есть на форуме по работе со стаканом котировок в qlua. Написал простейший скрипт и уперся в такой момент.
Вот скрипт:
function main ()
   StKot = getQuoteLevel2('SPBFUT','RNH3')
   NumBid = StKot.bid_count
   bid_quantity = StKot.bid[NumBid].quantity
   bid_price = StKot.bid[NumBid].price
   ...
end

Понятно, что в таблице спроса строки идут от "худшей", поэтому что получить лучший спрос в стакане - запрашиваю кол-во строк и беру последнюю. Ругается ,что нет такого индекса в этой таблице. Думаю, может начинает с нулевой строки. Делаю [NumBid - 1]. Ошибки не выдает, результат показывает, но на поверку обнаруживаю, что выдает 2-ю сверху позицию спроса в стакане.
При этом по StKot.offer[1] нормально выдает лучшее предложение в стакане.
Помогите, люди добрые, как получить "лучший" спрос из стакана?

p.s. окно стакана котировок открыто при работе скрипта
p.s. вариант получения данных через getParamEx понятен, я не понимаю, почему из стакана не цепляет?
Позиции на счете появляются уже после снятия заявки, Позиции на счете появляются уже после снятия заявки
 
О, я в тренде вопросов )))
Главное заключается в том, что многократный вызов колбэка утраивает все расчетные значения, которые я запрашиваю для будущего расчета средней стоимости сделки по заявке, поэтому по факту средняя стоимость сделки из одной большой заявки выходит правильно.
Позиции на счете появляются уже после снятия заявки, Позиции на счете появляются уже после снятия заявки
 
Цитата
Владимир написал:
Дмитрий, Не знаю, как прогрессивный люд, а я делаю только так. Только ещё нюанс: функция сверки с портфелем тоже глючит, и в данный момент она у меня отключена.  
Понятно. А если говорить про расчетным метод контроля, не могли бы еще подсказать, почему OnTrade - функция обратного вызова по сделке - вызывается по каждой сделке ровно 3 раза, а не один? специально ставил счетчик по номеру заявки и сравнивал с таблицей сделок - кол-во по счетчику в OnTrade набегает всегда ровно в 3 раза больше кол-ва сделок. Наверное, что-то кроме самой сделки еще колбэк ловит?
Позиции на счете появляются уже после снятия заявки, Позиции на счете появляются уже после снятия заявки
 
Цитата
Владимир написал:
Дмитрий, А зачем Вы вообще связываетесь с getFuturesHolding? Вы знаете, что заявка исполнена (или исполнена частично, или не исполнена вообще). Портфель тоже нередко глючит (это если у брокера его смотреть). Так контролируйте всё, что угодно по собственным данным скрипта, ведите портфель сами, периодически сверяясь с брокером.
Вот оно как прогрессивный люд то делает... Понял, попробую так, расчетно держать портфель, по итогам операции или по таймингу делать сверку с портфелем в терминале. Спасибо.  
Позиции на счете появляются уже после снятия заявки, Позиции на счете появляются уже после снятия заявки
 
Цитата
Евгений написал:
где то в коде скорее всего ошибка
там код проще простого, я везде месседжей и "ловушек" понаставил, код идет без ошибок и хронологически по месседжам видно, что заявка исполнена, а позиций нет
Позиции на счете появляются уже после снятия заявки, Позиции на счете появляются уже после снятия заявки
 
Люди добрый и умные, помогите начинающему скриптеру. Голову сломал.
Выставляю заявку на продажу фьючерса и контролирую ее по битовым флагам на исполнение.
Типа так:
 if bit.band(trade.flags,1) == 0 and bit.band(trade.flags,2) == 0 then
   ZayavkaIspolnena_F_Buy = true
 end
После получения (строго после) условия ZayavkaIspolnena_F_Buy = true проверяю позицию по getFuturesHolding и часто получается так, что позиции теряются (не показывает getFuturesHolding), хотя заявка исполнена.
Ставил задержку между ZayavkaIspolnena_F_Buy и  getFuturesHolding sleep (1000) - уже лучше, но на 5 раз проскочило опять, в этот раз была заявка на 20 позиций реализована частями (15+3+1+1), а на getFuturesHolding выдало наличие =18 (а по факту в портфеле появились все 20 фьючерсов), т.е. последние 2 сделки не успели по системе перейти в позиции до сработки getFuturesHolding.
Топорно увеличивать еще паузу между ZayavkaIspolnena_F_Buy и  getFuturesHolding - но до какого интервала? да и не правильно это, концепт моего бота подламывает.
Уверен, что опытные товарищи эту проблему легко решают в коде, подскажите, как точно получить значение реализованной заявки.

p.s. по-простому расчетно брать из кол-ва в заявке мне не вариант, т.к. скрипт подразумевает частичное исполнение заявки и снятие ее, потом расчет, и перевыставление на остаток, т.е. мне надо контролировать позицию к заявке по наличию в портфеле
Позиции по инструментам - валюта, Позиции по инструментам - валюта - не показывает
 
На валютном счете произвел покупку 3000$, в итоге в "позициях по инструментам" по валютному счете показывает 0, а в позициях по деньгам = 3000USD.
Не могу понять, что тогда означает окно "позиция по инструментам" применительно к валютному счету, если собственно валюта в нем не считается за инструмент?
OnStop, Не могу задать время на остановку скрипта из диалога управления
 
Спасибо за ответ.
Но я понимаю, что функция OnStop не прерывает выполнение программы сама, а лишь вызывается при остановке и возвращает время на остановку скрипта. Я про другое. У меня эта 1мс никак не выходит. Любой скрипт останавливается ровно 5 секунд (которые заданы по умолчанию) и никак не реагирует на мои данные по return - делал и мало (1мс), и много (30с) - все одно пауза при нажатии "остановить" ровно 5с.
OnStop, Не могу задать время на остановку скрипта из диалога управления
 
Такая функция (без всяких еще дописок в основном коде) должна мгновенно (за 1 мс) останавливать скрипт или нет?
function OnStop()
return 1
end
в примерах есть еще переменная stopped (которой присваивается true в этой функции) - зачем она?
p.s. я новичок - чур не обзывать тупым ))
Закладки
 
спасибо
Закладки
 
Добрый день.
А по этой теме есть какие-то подвижки на момент 2022 года?
KILL_ORDERS, KILL_ORDERS не отрабатывает
 
Вот нельзя было конкретнее написать ,что лишнее "S" в конце, должно быть 'KILL_ORDER' )))
пришлось еще голову поломать, глаз-то уже замылился ))
Спасибо !!!
KILL_ORDERS, KILL_ORDERS не отрабатывает
 
Ой, картинка не подгрузилась.
Ну, в общем, там
" TRANS_ID 1651566806 "
KILL_ORDERS, KILL_ORDERS не отрабатывает
 
"1) отобразите сообщение, которое возвращает sendTransaction;"
Это которое у меня в коде месседжем? Вот:
[img][/img]
KILL_ORDERS, KILL_ORDERS не отрабатывает
 
OnTransReply не вызывается по транзакции transaction_stock_kill (в этом же скрипте ранее транзакция на выставление заявки - по ней OnTransReply вызывается и .result_msg выходит). Т.е. физического действия не происходит, хотя программно транзакция проходит, т.к. TRANS_ID присваивается
KILL_ORDERS, KILL_ORDERS не отрабатывает
 
 CLASSCODE - у меня переменной вставлено, там все правильно, заявка выставляется до этого
KILL_ORDERS, KILL_ORDERS не отрабатывает
 
Такой простенький код:

function transaction_stock_kill ()
   message('transaction_stock_kill poshlo '..Num_Z [j])
   t_kill = tostring (os.time())
   transaction_kill = {
       CLASSCODE = ClassCodeSt,
       SECCODE = "GAZP",
       ACTION = 'KILL_ORDERS',
       ORDER_KEY = tostring (Num_Z [j]),
       TRANS_ID = t_kill
                                  }
  sendTransaction (transaction_kill)
  message('TRANS_ID '..transaction_kill.TRANS_ID)
end

Номер заявки совпадает с табличным в QUIKе (первое сообщение в коде). Транзакции на снятие заявки проходит - второе сообщение в конце с TRANS_ID выходит (т.е. транзакция прошла), а по факту снятие активной заявки не происходит, почему так? чего не хватает?  
OnTransReply для опционов, OnTransReply для опционов не вызывается
 
В таблицах транзакций и сообщений все ноРм
OnTransReply для опционов, OnTransReply для опционов не вызывается
 
В таблицах транзакций и сообщений все ном, записей по ошибкам нет.

Сегодня и по фьючерсу не вызывается...
Cкрипт подачи заявки стандартный, заявка то выставляется, а OnTransReply не вызывается. Проверяю на простое действие:

function OnTransReply (order)
message ('chto-to otozvalos')
end

выходит только стандартное окно выставленной заявки, а моего окна не выходит.

p.s. как листать окна знаю, нет там его.
это я в демо-версии балуюсь, может в этом дело?
OnTransReply для опционов, OnTransReply для опционов не вызывается
 
Забыл написать, что пробую в демо-версии, может в этом дело?
OnTransReply для опционов, OnTransReply для опционов не вызывается
 
Напрочь отказывается вызываться функция OnTransReply для опционов. Один в один написан код для заявки на фьючерс и опцион, по факту обе заявки системой выставляются, по итогу  OnTransReply для фьючерса вызывается, а для опциона нет. Пробовал и вместе, и отдельно опцион запускать - ни фига.
p.s. подскажите, а есть на форуме поисковик по ключевым словам? может этот вопрос был в другим темах, но при отсутствии поисковика очень трудоемко все листать  
Сохранение результатов работы скрипта в файл
 
Спасибо за ответ.
Очевидно, что Ваш уровень знаний в QLUA значительно выше моего, поэтому мои формулировки могут показаться дилетанскими, не спорю.
Правильно тогда мой вопрос будет звучать как:
Результатом работы скрипта получается таблица как ТИП ДАННЫХ, которую нужно сохранить в файл.
Цитата
Цитата: Вам надо найти реализацию нагугленной вами этой функции или написать ее самостоятельно
в этом и вопрос как ее написать - никаких функций для этого я не нашел, даже зацепочки.
Неужели такая стандартная задача до этого никем в QLUA была не востребована и не изучена?
Сохранение результатов работы скрипта в файл
 
Не могу разобраться как сохранить результаты работы скрипта в файл.
Нагуглил про функцию SaveTable, но она не хочет работать (или я не понимаю как ее использовать).
Что-то типа
t_id = AllocTable()
--дальше формируем таблицу, в конце прошу скинуть в файл:
SaveTable(t_id, SaveResalt)
и в итоге:
attempt to call a nil value (global 'SaveTable')

p.s. таблица сама на экран выводится нормально, никаких ошибок не выдает
Как обойти attempt to index a nil value ?, Как обойти attempt to index a nil value при отсутствии реальных значений в таблице
 
Спасибо, все получилось
Как обойти attempt to index a nil value ?, Как обойти attempt to index a nil value при отсутствии реальных значений в таблице
 
При выполнении этого фрагмента скрипта:
nLKOH = getDepoEx ("NC...", "10...", "LKOH", "NL...", 0).currentbal
выдает ошибку "attempt to index a nil value"
Я понимаю, почему система возвращает ошибку - позиций по "LKOH" просто нет в "позициях по инструментам", но пусть выдаст тогда значение 0 и не останавливает скрипт.
Как это реализовать?  
Страницы: 1
Наверх