launchd выполняет скрипт Python, но импорт не удается - PullRequest
4 голосов
/ 07 апреля 2011

Я написал скрипт на python, используя appscript для отслеживания моего текущего активного окна.Я запускаю его через launchd, но когда я делаю это, он не может импортировать appscript.Я установил PYTHONPATH в списке для launchd, но я думаю, что launchd не читает файлы .pth в пакетах сайта.Есть ли способ заставить это сделать это?

Мой сценарий здесь: https://github.com/katylava/macwintracker

Это запустенный plist:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
  <dict>
    <key>label</key>
    <string>com.katylavallee.wintracker</string>
    <key>ProgramArguments</key>
    <array>
        <string>/Users/kyl/Library/Application Support/com.katylavallee.wintracker/wintracker.py</string>
        <string>1</string>
        <string>1</string>
    </array>
    <key>Environment Variables</key>
    <dict>
      <key>PYTHONPATH</key>
      <string>/opt/local/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages</string>
    </dict>
    <key>StandardErrorPath</key>
    <string>/Users/kyl/Library/Logs/com.katylavallee.wintracker/wintracker_err.log</string>
    <key>StandardOutPath</key>
    <string>/Users/kyl/Library/Logs/com.katylavallee.wintracker/wintracker.log</string>
    <key>StartInterval</key>
    <integer>3</integer>
  </dict>
</plist>

И ошибка:

Traceback (most recent call last):
  File "/Users/kyl/Library/Application Support/com.katylavallee.wintracker/wintracker.py", line 5, in <module>
    from appscript import app, its
ImportError: No module named appscript

Сценарий python отлично работает из командной строки.

Ответы [ 2 ]

6 голосов
/ 07 апреля 2011

Скорее всего, для запуска вашего скрипта запускается системный Python (/usr/bin/python), а не MacPorts Python (/opt/local/bin/python2.6), на котором установлена ​​appscript. Что должно работать (не проверено!), Это вставить путь MacPorts Python в качестве первого Program Argument перед путем к сценарию. И в этом случае вам не нужно указывать PYTHONPATH. Теоретически, вы можете сделать то, что у вас есть, до тех пор, пока MacPorts Python был настроен совместимым образом (т. Е. Схожие арки, цели развертывания и т. Д.) С системным Python, но вам, вероятно, не нужно или не нужно идти по этому пути. .

Другой подход заключается в том, чтобы изменить строку shebang (первую строку) сценария на путь экспликации к Python MacPorts:

#!/opt/local/bin/python2.6

Причина, по которой это работает в оболочке командной строки, заключается в том, что один из ваших файлов профиля оболочки, например, .bash_profile, изменяет переменную среды PATH, чтобы сначала включить путь к MacPorts Python (/opt/local/bin), чтобы /usr/bin/env python сначала находит MacPython python. При запуске через launchd оболочка не включается, поэтому манипуляция PATH не происходит; только пути по умолчанию ищутся, что означает /usr/bin/env python выполняет /usr/bin/python.

0 голосов
/ 15 марта 2016

Вы также можете использовать полный путь к питону в ProgramArguments.(Подробнее здесь: Запуск скрипта Python с Launchd: импорт не найден )

   <key>ProgramArguments</key>
    <string>/path/to/your/python</string>
    <string>/path/to/your/script</string>
...