|
0 / 0 / 0
Регистрация: 22.02.2015
Сообщений: 45
|
|||||||||||
Запуск подпроцессов из функции17.05.2018, 18:14. Показов 7357. Ответов 4
Метки нет (Все метки)
Пытаюсь сделать мультипроцессное приложение для ускорения работы моего скрипта, начал с простого примера:
Кликните здесь для просмотра всего текста
Traceback (most recent call last):
File "<string>", line 1, in <module> File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 105, in spawn_main exitcode = _main(fd) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 114, in _main prepare(preparation_data) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 225, in prepare _fixup_main_from_path(data['init_main_from_path']) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 277, in _fixup_main_from_path run_name="__mp_main__") File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\runpy.py", line 263, in run_path pkg_name=pkg_name, script_name=fname) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\runpy.py", line 96, in _run_module_code mod_name, mod_spec, pkg_name, script_name) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\runpy.py", line 85, in _run_code exec(code, run_globals) File "C:\Users\userweather\Desktop\Projects\P ython\003_Parallel\test.py", line 3, in <module> mainn.main() File "C:\Users\userweather\Desktop\Projects\P ython\003_Parallel\mainn.py", line 16, in main p1.start() File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\process.py", line 105, in start self._popen = self._Popen(self) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\context.py", line 223, in _Popen return _default_context.get_context().Process._ Popen(process_obj) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\context.py", line 322, in _Popen return Popen(process_obj) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\popen_spawn_win32 .py", line 33, in __init__ prep_data = spawn.get_preparation_data(process_obj._ name) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 143, in get_preparation_data _check_not_importing_main() File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 136, in _check_not_importing_main is not going to be frozen to produce an executable.''') RuntimeError: An attempt has been made to start a new process before the current process has finished its bootstrapping phase. This probably means that you are not using fork to start your child processes and you have forgotten to use the proper idiom in the main module: if __name__ == '__main__': freeze_support() ... The "freeze_support()" line can be omitted if the program is not going to be frozen to produce an executable. Traceback (most recent call last): File "<string>", line 1, in <module> File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 105, in spawn_main exitcode = _main(fd) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 114, in _main prepare(preparation_data) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 225, in prepare _fixup_main_from_path(data['init_main_from_path']) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 277, in _fixup_main_from_path run_name="__mp_main__") File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\runpy.py", line 263, in run_path pkg_name=pkg_name, script_name=fname) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\runpy.py", line 96, in _run_module_code mod_name, mod_spec, pkg_name, script_name) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\runpy.py", line 85, in _run_code exec(code, run_globals) File "C:\Users\userweather\Desktop\Projects\P ython\003_Parallel\test.py", line 3, in <module> mainn.main() File "C:\Users\userweather\Desktop\Projects\P ython\003_Parallel\mainn.py", line 16, in main p1.start() File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\process.py", line 105, in start self._popen = self._Popen(self) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\context.py", line 223, in _Popen return _default_context.get_context().Process._ Popen(process_obj) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\context.py", line 322, in _Popen return Popen(process_obj) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\popen_spawn_win32 .py", line 33, in __init__ prep_data = spawn.get_preparation_data(process_obj._ name) File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 143, in get_preparation_data _check_not_importing_main() File "C:\Users\userweather\AppData\Local\Prog rams\Python\Python36-32\lib\multiprocessing\spawn.py", line 136, in _check_not_importing_main is not going to be frozen to produce an executable.''') RuntimeError: An attempt has been made to start a new process before the current process has finished its bootstrapping phase. This probably means that you are not using fork to start your child processes and you have forgotten to use the proper idiom in the main module: if __name__ == '__main__': freeze_support() ... The "freeze_support()" line can be omitted if the program is not going to be frozen to produce an executable. Скажите, как реализовать задуманное, чтобы вызов подпроцессов осуществлялся в рамках функции (или даже метода класса).
0
|
|||||||||||
| 17.05.2018, 18:14 | |
|
Ответы с готовыми решениями:
4
Как запретить повторный запуск функции или оюойти условие в данной функции Запуск функции
|
|
|
||||||
| 17.05.2018, 18:31 | ||||||
|
В ошибке все написано - на windows при мультипроцессинге нужно использовать точку входа. Привыкайте писать везде, даже если это кажется вам странным:
1
|
||||||
|
0 / 0 / 0
Регистрация: 22.02.2015
Сообщений: 45
|
|
| 17.05.2018, 23:43 [ТС] | |
|
Garry Galler, т.е. правильно я понимаю, что внутри функции нельзя создать дочерние процессы, и, как следствие, нельзя поместить мультипроцессинг в логику какого-нибудь класса, чтобы человек, который этот класс использует, ни о каких мультипроцессах не задумывался
0
|
|
|
|
|||||||
| 18.05.2018, 00:21 | |||||||
|
Можно. Просто есть простая идиома: используешь код с мультипроцессингом - изволь запускать его из точки входа if __name__ == "__main__"
Это во всех документациях по мультипроцессам написано. Но обязательно это только на windows - в linux процессы форкаются проще, поэтому интерпретатору не требуется "водораздел" между кодом и его запуском.
P.S. Собственно, сама точка входа: if __name__ == "__main__" это обычный стиль программирования на python: сначала код, затем его вызов в точке входа в скрипт. Это принято писать всегда и везде - поэтому у большинства никаких проблем с мультипроцессингом не возникает. Добавлено через 13 минут P.P.S. В любом случае интерпретатор скажет, что делать в traceback'е ошибки:
1
|
|||||||
|
0 / 0 / 0
Регистрация: 22.02.2015
Сообщений: 45
|
|
| 18.05.2018, 15:04 [ТС] | |
|
Garry Galler, Спасибо, теперь все работает. Хочу задать еще один вопрос, у меня есть скрипт, где в цикле некоторое количество раз N вызывается функция calc(), набор аргументов при вызове функции calc() каждый раз уникальный. Хотелось бы сделать список задач, каждый элемент которого - аргументы для очередного вызова функции calc(), и чтобы эти задачи выполнились некоторым количеством процессов n, так, чтобы когда какой-нибудь из n процессов завершится - тут же запускался бы другой процесс с новым заданием из списка задач и так до тех пор, пока все N задач не будут просчитаны.
Я могу запустить n процессов и для каждого из них вызвать .join(), после того как все процессы отработают - запустить следующие n процессов, но тогда n-1 завершившийся процесс будет ждать пока не закончится процесс последний, хотя вместо этого могли бы работать. Скажите, как решить эту задачу, избежав простоя процессорной мощности? Прошу прощение за подобные вопросы, это мое первое мультипроцессное приложение.
0
|
|
| 18.05.2018, 15:04 | |
|
Помогаю со студенческими работами здесь
5
Запуск функции в цикле Запуск функции по условию
Запуск отдельной функции
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
|
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут.
https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc
Первый документ красиво выглядит, но без схемы.
Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
|
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере".
Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
|
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти".
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
В качестве источника данных. . .
|
|
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер
Написал заготовку:
dotnet new console --aot -o UrlHandler
var items = args. Split(":");
var tag = items;
var id = items;
var executable = args;. . .
|
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
|
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений.
9TO2GP2bpX4
a42b81fb172ffc12ca589c7898261ccb/
https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/
Слева синяя линия -. . .
|
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. .
Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
|