在没有标准库的情况下嵌入 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的主要内容,如果未能解决你的问题,请参考以下文章

在没有非标准库的嵌入式系统上进行对象检测的建议

Python3---标准库json

2014025688《嵌入式程序设计》第五周学习总结

python3.5学习第二章标准库,bytes

在不使用标准库的情况下编写 scipy 函数(指数幂)

Python3.9标准库math中的函数汇总介绍(53个函数和5个常数)