在没有标准库的情况下嵌入 Python3
Posted
技术标签:
【中文标题】在没有标准库的情况下嵌入 Python3【英文标题】:Embed Python3 without standard library 【发布时间】:2016-04-15 21:51:39 【问题描述】:编辑:我在这里问了一个相反的问题:How to embed Python3 with the standard library
此处提供了 Python2 的解决方案:Is it possible to embed python without the standard library?
但是,Python3 在Py_Initialize();
上失败了:
Fatal Python error: Py_Initialize: unable to load the file system
codec ImportError: No module named 'encodings'
这是有道理的,因为 py3 源文件默认为 utf-8。所以它似乎需要一个外部二进制文件才能解析 py3 源文件。
那该怎么办?
看起来我需要在我的系统 Python 安装中找到 encodings
二进制文件,将其复制到我的项目树中,并且可能设置一些环境变量 PYTHONPATH(?) 以便我的 libpython.dylib 可以找到它。
是否可以避免这种情况?如果没有,谁能澄清我需要采取的步骤?还会有更多的小问题吗?
注意:为了后代,这就是我如何将独立的 libpython.dylib 链接到我在 OSX 上的项目:
首先我找到我的系统 Python 库:/usr/local/Frameworks/Python.framework/Versions/3.4/Python
(在我的例子中,它是通过自制软件安装的)。
现在我:
将 .dylib 复制到我的项目文件夹中,创建 ./Libs/libpython3.4.1_OSX.dylib
进入build settings -> linking
并将other linker flags
设置为-lpython3.4.1_OSX
此时它似乎可以工作。但是,如果您知道尝试在全新的 OSX 安装上构建它,它将失败。这是因为:
$ otool -D ./libpython3.4.1_OSX.dylib
./libpython3.4.1_OSX.dylib:
/usr/local/Frameworks/Python.framework/Versions/3.4/Python
.dylib 仍然保留它的旧位置。 .dylib 包含指向其位置的链接对我来说真的很奇怪,因为任何使用它的东西都必须知道它在哪里才能首先调用它!
我们可以通过以下方式纠正这个问题:
$ install_name_tool -id @rpath/libpython3.4.1_OSX.dylib libpython3.4.1_OSX.dylib
但同样在我们的 Xcode 项目中,我们必须:
进入build phases
。添加一个copy files
步骤,将libpython3.4.1_OSX.dylib
复制到Frameworks
(这是放置它的正确位置)。
进入build settings -> linking
并将runpath search paths
设置为@executable_path/../Frameworks/libpython3.4.1_OSX.dylib
最后我需要进入edit scheme -> run -> arguments -> environment variables
并添加PYTHONHOME
值../Frameworks
我怀疑要让这个工作我还需要添加一个PYTHONPATH
链接:https://mikeash.com/pyblog/friday-qa-2009-11-06-linking-and-install-names.htmlhttp://qin.laya.com/tech_coding_help/dylib_linking.htmlhttps://github.com/conda/conda-build/issues/279#issuecomment-67241554Can you please help me understand how Mach-O libraries work in Mac Os X?http://nshipster.com/launch-arguments-and-environment-variables/
【问题讨论】:
恐怕还有更多要求;例如,导入模块主要由importlib
包处理。我认为 Python 3 不能再被剥离 stdlib 了,至少不能没有至少一个子集。
encodings
不是程序。这是一个python包
尝试阅读 py2app 的启动器代码的源代码。它对 OS X 和启动和运行 python 了解很多。
参见这里***.com/questions/40634115/…
我认为它应该很好用
【参考方案1】:
我已经尝试过这一点,但在没有 Python 库的情况下嵌入 Python 3 所花费的时间比您想花费的时间要多。
库中的一些模块是 Python 3 运行所必需的,如果没有它们,它需要进行大量修改才能工作。
【讨论】:
这根本不是一个好的答案,没有解释为什么你所说的会是这种情况,也没有解释 python 2.x 工作于此和 python 3.x 不工作之间的不连续性. Python 3 目前有几个硬编码的依赖,例如 encodings.utf_8、encodings.latin_1、builtins、io。它在初始化期间导入模块。在 Python 2 中情况并非如此。没有什么可说的了。以上是关于在没有标准库的情况下嵌入 Python3的主要内容,如果未能解决你的问题,请参考以下文章