@Fox Привет.Я описывал задачу в этой теме https://community.bablosoft.com/topic/27417/вызов-многопоточной-функции
Дело в том,что я не могу вообще никак перевести свой скрипт на многопоток,у меня тупо,что в вызове функции в многопоток,что просто обычный многопоток,выполняет свою работу с данными по очереди,а не одновременно.И это очень сильно бьет по времени,а нужна именно скорость обработки.Все уже готово и скрипт рабочий полностью,но скорость обработки заставила воспользоваться многопотоком.Ранее,подобных проблем не замечал,а сейчас элементарную задачу не могу уже несколько дней решить.
Скрипт очень простой и работает без браузера вообще,в скрипте используется только одно взаимодействие с гет запросом.Пример скрипта я приложил в этой теме(но без запросов),он точно почти такой же,как и основа.
Логика такова:
1)Запускается скрипт (без всяких ресурсов изначально и данных) и создаются два ресурса.
2)Делается запрос на сайт,который обрабатывается в отдельной функции,т.е. обрабатывает полученные строки и записывает в ресурс.
3)Вызывается функция в несколько потоков,которая работает (должна работать) с каждой строкой из созданного ранее ресурса(уникальной)в отдельном потоке.Данные обрабатываются и записываются во второй ранее созданный ресурс.
4)Как только данные обработаны,ресурс переводится в список и список записывается в файл.Более ничего не делается.
-Сперва я думал,что проблема в создаваемых в ходе работы ресурсах,но нет.Создавал изначально ресурсы и то же самое было.
-Потом пробовал брать из файлов значения\потом создавать файлы по ходу и из них брать данные\сохранять напрямую пытался и.т.д
-Возможно думал стоят какие то ограничения из за слабого пк с 4 гб оперативы и взял сервер с 64 гб,но как обрабатывалась строка за 5 минут на моем пк,так же по скорости и на серваке.Ладно, с этим я уже ничего не поделаю из за регулярок в проекте,согласен.Но вот перевести на поток и хотя бы по 10 строк одновременно обрабатывать,очень бы помогло.А сейчас в любом случае,у меня,сколько бы потоков не выставил - работает все равно как один,просто по очереди разный поток берет свои данные(
Выполнение абсолютно другой функции
-
BAS выполняет совсем другую функцию чем я его прошу.
Проблема в режиме запуска, в режиме записи отрабатывает на ура.
лог:
[957890551] [19:03:34] Поток №1 : Начало работы: Wed May 22 2024 19:03:34 GMT+0500 (RTZ 4 (
[986048669] [19:05:59] Поток №1 : Ищем координаты камень
[711509071] [19:06:12] Поток №1 : камень
[635485856] [19:06:16] Поток №1 : 1 караван серебра
[986048669] [19:06:32] Поток №1 : Ищем координаты камень
[711509071] [19:06:44] Поток №1 : камень
[635485856] [19:06:49] Поток №1 : 2 караван серебраBAS: 27.2.0
Windows 10 x 64

Вызов функции caravan_silver после которой в лог попадает
[635485856] [19:06:16] Поток №1 : 1 караван серебра

но функция caravan_silver должна писать в лог немножко другое.


а это то, что пишет функция caravan_stone что есть в логах
[986048669] [19:05:59] Поток №1 : Ищем координаты камень
[711509071] [19:06:12] Поток №1 : камень
Т.е. зашли по if правильно, но почему то вызвали функцию которая в конце набора if-ов, промежуточные if-ы так же проигнорированны -
Что мы должны понять со скриншотов ?
Давайте накину предположений что ли.- У вас где то вложенность, из не найдя чего то скрипт выкидывает вас в конец работы, к элементу который вне вложенности.
- Не находит картинку в точно таком соответствии, извращение но попробуйте поставить схожесть на 60%
- Игнор ошибок.
Ну или фазы луны не сошлись... по скриншотам ничего другого сказать увы не возможно.
-
@AKJ said in Выполнение абсолютно другой функции:
что такое кубики и как они включаются\выключаются?
Действия проекта. Включаются\выключаются - после выбора действия правой кнопкой мыши по полю редактора скрипта, далее будет менюшка. Действие отключено только в режиме записи, в режиме запуска отключенное действие работает!