Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/313.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
launchd执行python脚本,但导入失败_Python_Launchd - Fatal编程技术网

launchd执行python脚本,但导入失败

launchd执行python脚本,但导入失败,python,launchd,Python,Launchd,我使用appscript编写了一个python脚本来跟踪当前活动的窗口。我通过launchd运行它,但当我这样做时,它无法导入appscript。我已经在plist中为launchd设置了PYTHONPATH,但是我认为launchd没有读取站点包中的.pth文件。有没有办法做到这一点 我的脚本如下: 这是启动层: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE plist PUBLIC "-//Apple Computer//

我使用appscript编写了一个python脚本来跟踪当前活动的窗口。我通过launchd运行它,但当我这样做时,它无法导入appscript。我已经在plist中为launchd设置了PYTHONPATH,但是我认为launchd没有读取站点包中的.pth文件。有没有办法做到这一点

我的脚本如下:

这是启动层:

<?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>

标签
com.katylavallee.wintracker
程序参数
/Users/kyl/Library/Application Support/com.katylavallee.wintracker/wintracker.py
1.
1.
环境变量
蟒蛇
/opt/local/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages
标准错误路径
/Users/kyl/Library/Logs/com.katylavallee.wintracker/wintracker\u err.log
标准门诊
/Users/kyl/Library/Logs/com.katylavallee.wintracker/wintracker.log
星际旅行社
3.
错误是:

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
回溯(最近一次呼叫最后一次):
文件“/Users/kyl/Library/Application Support/com.katylavallee.wintracker/wintracker.py”,第5行,在
从appscript导入应用程序,其
ImportError:没有名为appscript的模块

python脚本在命令行中运行良好。

很可能是启动系统python(
/usr/bin/python
)来执行脚本,而不是安装了
appscript
的MacPorts python(
/opt/local/bin/python2.6
)。应该做的(未测试!)是在脚本路径之前插入MacPorts Python路径作为第一个
程序参数。在这种情况下,您不需要指定
PYTHONPATH
。理论上,只要MacPorts Python的配置与系统Python兼容(即类似的ARCH、部署目标等),您就可以使现有的工作正常进行,但您可能不希望或不需要这样做

另一种方法是将脚本的shebang行(第一行)更改为MacPorts Python的显式路径:

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

这在命令行shell中起作用的原因可能是您的一个shell配置文件,例如
.bash_profile
,修改了
PATH
环境变量,首先包括MacPorts Python(
/opt/local/bin
)的路径,以便
/usr/bin/env-Python
首先找到MacPython
Python
。当运行
launchd
时,不涉及shell,因此不会发生
PATH
操作;只搜索默认路径,这意味着
/usr/bin/env python
执行
/usr/bin/python

您还可以在ProgramArguments中使用python的完整路径。(更多详情请参见此处:)

编程参数
/path/to/your/python
/路径/到/您的/脚本

谢谢!我完全看错了方向。我修复了它,因此我的安装脚本将shebang路径替换为
whichpython
的输出。为了完整起见,我将EnvironmentVariable保留在那里,并为PATH添加了一个键。
   <key>ProgramArguments</key>
    <string>/path/to/your/python</string>
    <string>/path/to/your/script</string>