python - 使用 MinGW 链接到 Python

标签 python mingw

我不想创建一个嵌入 python 解释器的跨平台程序,并用 MinGW 编译它。但是 Python 二进制发行版不提供 MinGW 链接的库(仅用于 Visual C++ 的 python32.lib),并且 Python 源代码包不支持使用 MinGW 进行编译。

我尝试使用 -lpython32 链接到 Mingw 中的 python32.lib 但它仍然会生成如下错误:

main.cpp: undefined reference to `_imp__Py_Initialize'
main.cpp: undefined reference to `_imp__Py_Finalize'

如何在 MinGW 中链接 Python?我真的不想改用 Visual C++。

最佳答案

使用 binutils 中的 nm 和 dlltool,您应该能够为 gcc 重建库:

echo EXPORTS > python32.def
nm python32.lib | grep " T _" | sed "s/.* T _//" >> python32.def
dlltool --input-def python32.def --dllname python32 --output-lib libpython32.a

python_test.c:

#include "Python.h"

int main(int argc, char *argv[]) {
    Py_Initialize();
    PyRun_SimpleString("from time import time,ctime\n"
                       "print('Today is',ctime(time())\n)");
    Py_Finalize();
    return 0;
}

编译:

gcc -Wall -IC:\Python32\include -LC:\Python32\libs -o python_test.exe python_test.c -lpython32

测试:

C:\python_test.exe
Today is Mon Jul 18 08:50:53 2011

编辑:如果您不想自己在 x64 上构建它,您可以从 Christoph Gohlke 的 Unofficial Windows Binaries for Python Extension Packages 下载它的多个版本。 .

编辑:这是一个基于 Tools/msi/msi.py 中现有函数的 Python 版本:

import subprocess
import warnings
import re

NM = 'x86_64-w64-mingw32-nm'
DLLTOOL = 'x86_64-w64-mingw32-dlltool'
EXPORT_PATTERN = r'^[_]{1,2}imp_(?P<export>.*) in python\d+\.dll'

def build_libpython(ver, nm=NM, dlltool=DLLTOOL,
                    export_pattern=EXPORT_PATTERN):
    pylib = 'python%s.lib' % ver
    pydef = 'python%s.def' % ver
    pydll = 'python%s.dll' % ver
    libpy = 'libpython%s.a' % ver
    warning = '%s failed - ' + '%s not built' % libpy
    match_export = re.compile(export_pattern).match
    cmd_nm = [nm, '-Cs', pylib]
    cmd_dlltool = [dlltool, 
                   '--dllname', pydll, 
                   '--def', pydef,
                   '--output-lib', libpy]
    with open(pydef, 'w') as f:
        f.write('LIBRARY %s\nEXPORTS\n' % pydll)
        p_nm = subprocess.Popen(cmd_nm, 
                                stdout=subprocess.PIPE,
                                universal_newlines=True)
        for line in sorted(p_nm.stdout):
            m = match_export(line)
            if m:
                f.write(m.group('export') + '\n')
        if p_nm.wait() != 0:
            warnings.warn(warning % nm)
            return False
    if subprocess.call(cmd_dlltool) != 0:
        warnings.warn(warning % dlltool)
        return False
    return True

例如:

import os
for n in (27, 33, 35):
    pylib = 'python%s.lib' % n
    if os.path.exists(pylib):
        build_libpython(n)
        pydef = 'python%s.def' % n            
        lc_def = sum(1 for line in open(pydef))
        libpy = 'libpython%s.a' % n
        lc_lib = sum(1 for line in os.popen('ar -t %s' % libpy))
        assert lc_def == lc_lib

关于python - 使用 MinGW 链接到 Python,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6731100/

相关文章:

Python Web Scraping 表返回 None

python - 在 svm 中预测多类

c++ - 错误 : cannot convert 'float*' to 'qreal* {aka double*} in initialization

C++ 代码转储 "random"数据

python如何从列表列表中生成组合

python - 什么时候可以使用 "conda install"以及什么时候必须使用 "pip install"

python - 从 Tensorflow 数据集中分割数据时出现问题

c++ - "Occasional"段错误

mingw - SDL 1.3/2.0 设置

c - Gradle undefined reference `WinMain@16' 错误