我试图运行嵌入例如 ,我可以不加载从当前工作目录中的一个模块,除非我明确地把它添加到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
文档 :
如果脚本目录不可用(例如,如果解释器交互式的调用,或者如果脚本是从标准输入读取),路径[0] 是空字符串,其引导Python来首先搜索在当前目录中的模块 。
不知道这意味着什么用不可 ,但如果我打印sys.path[0]
不为空:
/usr/lib/pymodules/python2.7
你需要调用PySys_SetArgv(int argc, char **argv, int updatepath)
的相对进口工作。 这将增加正在执行的脚本的路径sys.path
,如果updatepath
是0
(参考文档以获取更多信息)。
下面应该做的伎俩
#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;
}
我有完全相同的问题,我解决它只是通过添加Py_Initialize();
和Py_Finalize();
希望能帮助你
我曾与Python 3.5做的是PySys_SetPath
能够从导入cwd
位置:
QString qs = QDir::currentPath();
std::wstring ws = qs.toStdWString();
PySys_SetPath(ws.data());
该Q
S IN是Qt的。