Zacząłem od tej króliczej nory, aby poznać zasady tworzenia skryptu instalacyjnego w Pythonie. Wybór Pythona był po prostu zakorzeniony w mojej znajomości, podczas gdy jestem pewien, że byłyby lepsze alternatywy dla tego zadania.
Celem tego skryptu była instalacja ROS na maszynie z uruchomionym skryptem, a także skonfigurowanie środowiska catkin. Wskazówki można znaleźć tutaj i tutaj , odpowiednio.
Obecny skrypt jest następujący:
subprocess.call(["sudo", "sh", "-c", "'echo \"deb http://packages.ros.org/ros/ubuntu $(lsb_release -sc) main\" > /etc/apt/sources.list.d/ros-latest.list'"])
subprocess.call(["sudo", "apt-key", "adv", "--keyserver", "hkp://ha.pool.sks-keyserver.net:80", "--recv-key", "0xB01FA116"])
subprocess.call(["sudo", "apt-get", "update"])
subprocess.call(["sudo", "apt-get", "install", "ros-kinetic-desktop-full", "-y"])
subprocess.call(["sudo", "rosdep", "init"])
subprocess.call(["rosdep", "update"])
subprocess.call(["echo", '"source /opt/ros/kinetic/setup.bash"', ">>", "~/.bashrc", "source", "~/.bashrc"])
subprocess.call(["sudo", "apt-get", "install", "python-rosinstall", "-y"])
mkdir_p(os.path.expanduser('~') + "/catkin_ws/src")
subprocess.call(["(cd "+ os.path.expanduser('~') + "/catkin_ws/src)"])
subprocess.call(["(cd "+ os.path.expanduser('~') + "/catkin_ws && catkin_make)"])
subprocess.call(["(cd "+ os.path.expanduser('~') + "/catkin_ws && source devel/setup.bash"])
Gdy skrypt jest aktualnie uruchomiony, pojawia się błąd:
Traceback (most recent call last):
File "setup.py", line 46, in <module>
subprocess.call(["(cd "+ os.path.expanduser('~') + "/catkin_ws/src)"])
File "/usr/lib/python2.7/subprocess.py", line 523, in call
return Popen(*popenargs, **kwargs).wait()
File "/usr/lib/python2.7/subprocess.py", line 711, in __init__
errread, errwrite)
File "/usr/lib/python2.7/subprocess.py", line 1343, in _execute_child
raise child_exception
OSError: [Errno 2] No such file or directory
Sprawdziłem, czy polecenie działa poprawnie po ręcznym wykonaniu z okna terminala i dlatego uważam, że jest to podstawowe nieporozumienie dotyczące sposobu obsługi tego skryptu i jego zakresu w systemie operacyjnym. Częścią, która sprawia mi wiele zamieszania, jest to, że skarży się, że nie jest w stanie zlokalizować podanego katalogu, podczas gdy sprawdziłem, że ten katalog istnieje. Gdy polecenie jest raczej drukowane z pythona i wklejane do okna terminala, nie występują błędy.
cwdargument docall
os.chdir()