我正在尝试运行embedding example并且我无法从当前工作目录加载模块,除非我明确地将其添加到sys.path
然后它可以工作:
PyRun_SimpleString("import sys");
PyRun_SimpleString("sys.path.append(\".\")");
Python不应该在当前目录中查找模块吗?
Edit1 :尝试使用以下方法导入模块:
Py_Initialize();
PyRun_SimpleString("import multiply");
它仍然失败并出现以下错误:
Traceback (most recent call last):
File "<string>", line 1, in <module>
ImportError: No module named multiply
Edit2 :来自sys.path
docs:
如果脚本目录不可用(例如,如果解释器是 以交互方式调用或者如果从标准输入读取脚本), path [0] 是空字符串,它将Python指向搜索模块 在当前目录中。
不确定不可用意味着什么,但是如果我打印sys.path[0]
它不是空的:
/usr/lib/pymodules/python2.7
答案 0 :(得分:18)
您需要调用PySys_SetArgv(int argc, char **argv, int updatepath)
才能使相对导入生效。如果sys.path
为updatepath
,这会将正在执行的脚本的路径添加到0
(有关详情,请参阅docs)。
以下应该做的伎俩
#include <Python.h>
int
main(int argc, char *argv[])
{
Py_SetProgramName(argv[0]); /* optional but recommended */
Py_Initialize();
PySys_SetArgv(argc, argv); // must call this to get sys.argv and relative imports
PyRun_SimpleString("import os, sys\n"
"print sys.argv, \"\\n\".join(sys.path)\n"
"print os.getcwd()\n"
"import thing\n" // import a relative module
"thing.printer()\n");
Py_Finalize();
return 0;
}
答案 1 :(得分:0)
我遇到了完全相同的问题,我只是通过添加Py_Initialize();
和Py_Finalize();
希望能帮到你
答案 2 :(得分:0)
我与python 3.5的关系是PySys_SetPath
,可以从cwd
位置导入:
QString qs = QDir::currentPath();
std::wstring ws = qs.toStdWString();
PySys_SetPath(ws.data());
其中的Q
是Qt。