Python OSError: [Errno 2]
Mam następujący kod, który próbuje uruchomić każde z poniższych "poleceń" w Linuksie. Moduł próbuje utrzymać każde z 2 poleceń uruchomionych, jeśli któreś z nich powinno ulec awarii z jakiegokolwiek powodu.
#!/usr/bin/env python
import subprocess
commands = [ ["screen -dmS RealmD top"], ["screen -DmS RealmD top -d 5"] ]
programs = [ subprocess.Popen(c) for c in commands ]
while True:
for i in range(len(programs)):
if programs[i].returncode is None:
continue # still running
else:
# restart this one
programs[i]= subprocess.Popen(commands[i])
time.sleep(1.0)
Po wykonaniu kodu jest wyrzucany następujący wyjątek:
Traceback (most recent call last):
File "./marp.py", line 82, in <module>
programs = [ subprocess.Popen(c) for c in commands ]
File "/usr/lib/python2.6/subprocess.py", line 595, in __init__
errread, errwrite)
File "/usr/lib/python2.6/subprocess.py", line 1092, in _execute_child
raise child_exception
OSError: [Errno 2] No such file or directory
Myślę, że brakuje mi czegoś oczywistego, czy ktoś widzi, co jest nie tak z powyższym kodem?
6 answers
Użyj ["screen", "-dmS", "RealmD", "top"]
zamiast ["screen -dmS RealmD top"]
.
Może również użyć pełnej ścieżki do screen
.
Jeśli program nadal nie może zostać znaleziony, możesz również przejść przez powłokę za pomocą shell=True
, ale wtedy musisz cytować i wymykać się parametrom itp. Pamiętaj, aby przeczytać informacje w dokumentach , jeśli planujesz to zrobić.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-01-24 18:41:59
Tylko domyślam się, że nie może znaleźć screen
. Spróbuj {[1] } lub cokolwiek which screen
Ci da.
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2009-05-23 17:29:51
Problem polega na tym, że Twoje polecenie powinno być podzielone. podprocesy wymagają, aby cmd był listą, a nie łańcuchem znaków. Nie powinno być:
subprocess.call('''awk 'BEGIN {FS="\t";OFS="\n"} {a[$1]=a [$1] OFS $2 FS $3 FS $4} END
{for (i in a) {print i a[i]}}' 2_lcsorted.txt > 2_locus_2.txt''')
To nie zadziała. Jeśli karmisz podproces łańcucha, zakłada się, że jest to ścieżka do polecenia, które chcesz wykonać. Komenda musi być listą. Sprawdź http://www.gossamer-threads.com/lists/python/python/724330 . Ponadto, ponieważ używasz przekierowania plików, powinieneś użyć subprocess.call(cmd, shell=True)
. Możesz również użyć shlex
.Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2015-01-20 19:14:37
commands = [ "screen -dmS RealmD top", "screen -DmS RealmD top -d 5" ]
programs = [ subprocess.Popen(c.split()) for c in commands ]
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-06-12 13:21:50
Dostałem ten sam błąd kiedy napisałem tak: -
subprocess.Popen("ls" ,shell = False , stdout = subprocess.PIPE ,stderr = subprocess.PIPE)
I problem jest rozwiązany kiedy zrobiłem shell=True . będzie działać
subprocess.Popen("ls" ,shell = False , stdout = subprocess.PIPE ,stderr = subprocess.PIPE, shell=True)
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-05-29 09:10:59
Na wszelki wypadek.. Ja też utknąłem z tym błędem i problemem było to, że moje pliki były w DOSIE zamiast UNIX tak w:
return subprocess.call(lst_exp)
Gdzie lst_exp jest listą args, jeden z nich został "nie znaleziony", ponieważ był w DOS-ie zamiast w Uniksie, ale wyrzucony błąd był taki sam:
File "/var/www/run_verifier.py", line 59, in main
return subprocess.call(lst_exp)
File "/usr/lib/python2.7/subprocess.py", line 522, in call
return Popen(*popenargs, **kwargs).wait()
File "/usr/lib/python2.7/subprocess.py", line 710, in __init__
errread, errwrite)
File "/usr/lib/python2.7/subprocess.py", line 1335, in _execute_child
raise child_exception
OSError: [Errno 2] No such file or directory
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2016-11-29 15:36:06