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?

Author: Caedis, 2009-05-23

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ć.

 64
Author: sth,
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.

 8
Author: Colin Burnett,
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.
 7
Author: kirbyfan64sos,
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 ]
 2
Author: Dennis Williamson,
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)

 1
Author: tejaswini teju,
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
 0
Author: Delphine,
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