Python SIP使用总结(Win&Linux通用)

本文介绍了Python中使用SIP调用C/C++模块的方法,包括在Windows和Linux环境下安装SIP的步骤,以及如何创建和编译C/C++模块,并在Python中使用。通过实例详细讲解了从编写C代码、SIP文件到生成Python模块的过程。
AI助手已提取文章相关产品:

        Python中使用C/C++模块有许多工具,大名鼎鼎的有SWIG(英文意思为:豪饮)、SIP(英文意思为:啜饮,小口的喝),还有boost.python等。其中SIP是从SWIG发展而来,专为Python调用C/C++模块使用的(看SIP的命名就能看出来,很有意思的)。

        SIP的使用方法,在官网的SIP Reference Guide中有介绍,不过那是针对至少有点经验的人员,对初学者来说,想十分钟快速上手还是有点难度的。这里就介绍下本人在使用SIP总结的需要注意的地方。(本着方便大家方便自己的原则,欢迎转载,无需征得本人同意,但请注明出处,最好是原文连接,图个人气,谢谢!)

        前提,本机上要装了Python、GCC(Windows下可以用MinGW,在我的Eclipse下配置CDT一文中有关于MinGW的安装介绍)。并把python.exe和MinGW下的bin文件路径添加到环境变量中。

第一部分:安装SIP

        Windows:

        将Riverbank上的sip的zip格式的代码包下载,将其解压到C:\Python27中,那么现在sip的文件夹路径为C:\Python27\sip-4.13.2\sip-4.13.2(你也可以将其解压到任何一个文件夹中,但这里为了叙述方便,就解压到我电脑上的Python的文件夹中)。

        打开Windows的cmd命令行,输如cd C:\Python27\sip-4.13.2\sip-4.13.2跳转到sip文件夹下。  

        输入python configure.py --platform win32-g++。进行配置,显示结果如下:

        再完成上一步后,输入mingw32-make,接着输入mingw32-make install。若无意外,SIP就安装完成了。

        常见问题:

        若是你的电脑上之前安装了Eclipse等其他软件,而将mingw32-make改成了make,那么就要将上面的mingw32-make命令改为make来使用。

        有个朋友说他按上面的方法使用make总是报错,仔细一问,才发现他的电脑上安装了Embacardero的RAD开发工具,也就是熟知的Delphi和C++ Builder的开发工具。在安装了这个工具后,在命令行中输入make,使用的总是Embacardero的C++ Builder的make。根据亲测,即使在配置的时候,使用python configure.py --platform win32-borland命令进行配置,对Emcarbadero的make也是无效的。这个配置命令产生的make文件,只是用于老版本的Borland C++ Builder的make命令。

        若要使用微软的VC的nmake,就要在配置时使用命令python configure.py --platform win32-msvc,其中win32-msvc使用的是VC6的nmake;win32-msvc.net使用的是VC2003的nmake;win32-msvc2005使用的是VC2005的nmake;win32-msvc2008使用的是VC2008的nmake。根据--show-platforms命令显示的结果,SIP的配置暂不支持VC2010和VS11下的nmake。若想知道SIP支持的所有平台和编译器,可以在命令行中使用python configure.py --show -platforms命令来查看。

        Linux:

        Linux下的SIP安装与之类似,甚至更简单,Linux的发行版如Ubuntu,都自动安装了python和gcc,无需配置环境变量。

        所以只要在官网上下载SIP的Linux下的tar.gz格式的代码包,解压到某个目录中。然后在终端中进入该目录,依次输入python configure.py --platform linux-g++;make;make install即可。

在Python中使用C/C++写的函数。

        1、首先,编写个C文件,功能是将两个数字相加并输出,命名为add.c,这个将成为在Python中的模块名,如下:

/* File : add.c */
int add(int x, int y) 
{  
	int g;  
	g = x + y;
	return g;
}

        2、接着,手工编写SIP文件,在使用SIP的过程中,一个C/C++的源码文件,必须对应一个同名的sip文件,命名为add.sip,如下:

/* Define the SIP wrapper to the add library. */
%Module(name=add, language="C")
int add(int x, int y);     

        如果是源程序是用C++写的,那么这里的(name=add, language="C")就可以省去。
        这里的C源码文件没有头文件,所以对应的sip文件很简单。如果C/C++的源码是实现部分,在实现部分还包括接口部分,即头文件。那么在相应的sip文件中需要用

%TypeHeaderCode
#include <word.h>
%End
        来包含相应的头文件。sip文件与正式的C/C++头文件相似,但与之不同的是:sip文件不包含相应的头文件的私有成员变量(private或protected)。更详细的sip文件编写规范,请参考riverbank官方网站上的说明文档SIP Reference Guide。

3、编译C文件。按照官网的说法,是编写configure.py,但别急,先做一些必不可少的工作。在命令行将add.c编译成add.o文件:输入

gcc -c add.c

接着,将这一步生成的add.o文件生产库文件:

ar -r libadd.a add.o

这两步在这里是为一个单独的C模块测试的,如果是大量的C模块,可以用一个makefile一并批量完成,这也是初学者容易模糊的地方。记住,需要将libadd.a文件复制到Python文件夹下的libs文件夹中。也可以将源代码直接编译成dll,命令为

        4、手工编写configure.py文件,同样,这个configure文件的编写也不难,看下规范就会了(要会鸟语。。。)。这里,我们模仿官网的模版写一个自己的configure.py。

import os
import sipconfig

# The name of the SIP build file generated by SIP and used by the build
# system.
build_file = "add.sbf"

# Get the SIP configuration information.
config = sipconfig.Configuration()

# Run SIP to generate the code.
os.system(" ".join([config.sip_bin, "-c", ".", "-b", build_file, "add.sip"]))

# Create the Makefile.
makefile = sipconfig.SIPModuleMakefile(config, build_file)

# Add the library we are wrapping.  The name doesn't include any platform
# specific prefixes or extensions (e.g. the "lib" prefix on UNIX, or the
# ".dll" extension on Windows).
makefile.extra_libs = ["add"]

# Generate the Makefile itself.
makefile.generate()

        5、运行configure.py,会生成一个makefile文件(直接用IDLE打开configure.py,按F5运行;或者命令行用python configure.py运行都可以)。
这里有个诡异的地方,有几个朋友在这一步会报错,说找不到add.sbf文件,而add.sbf文件应该是configure.py运行时调用相关函数自动产生的。若出现这个问题,请重新编译SIP。如果是Windows下,最好是在另一台机器上拷贝一个完整的包含能正常的SIP的Python文件夹,到有问题的机器上,将问题Python文件夹覆盖掉。

        6、在命令行输入make(这里会生成一个关于函数的警告,不用管它,我们是用来测试的。。。其他的应该没什么问题,若有问题请检查前面的步骤),生成add.pyd文件。然后再输入make install(将add.pyd文件装入到Python的Lib文件夹下的sit-packages文件夹中)。

        7、打开Python 的命令行,进行测试:

>>>import add
>>>add.add(4, 7)
11
>>>

(原谅我这么烂的模块名。。。)

提示:

(1)、这些文件可以放到Python的文件夹下新建的文件夹中(所有的操作在这个目录下的命令行窗口中使用)。注意,Python的父文件夹名不能有空格,否则会无法读取库文件。

(2)、使用MinGW,需要把~\MinGW\bin添加的环境变量中(Linux下则不必),这样才能使用gcc、make和ar等工具。

若还有什么注意的,我回继续补充。


您可能感兴趣的与本文相关内容

<think>好的,我需要帮助用户解决在Python 3.7环境下安装PyQt5的问题。用户之前遇到了wheel不兼容的问题,现在可能想确保正确安装。首先,我应该回顾之前的回答,确保信息一致且不重复。 首先,用户当前的问题是如何在Python 3.7下载PyQt5。我需要考虑PyQt5的版本兼容性。因为PyQt5的某些版本可能只支持特定Python版本。例如,用户之前遇到的是cp38的wheel,而这里需要cp37的。 接下来,我应该检查PyQt5在Python 3.7下的可用版本。根据记忆,PyQt5的较新版本可能不再支持Python 3.7,所以可能需要推荐较旧的版本,比如5.15.x或更早的。同时,用户可能需要通过pip安装,但有些版本可能需要从特定源下载。 另外,用户可能需要知道安装方法,比如使用pip直接安装,或者下载wheel文件手动安装。如果直接安装失败,可能需要指定版本号或者使用镜像源加速下载。 还要考虑操作系统,用户之前是Windows,但这里没有说明,可能需要询问或假设。如果是Windows,需要确认是32位还是64位,但用户可能已经知道,所以可以给出通用建议。 另外,可能需要提醒用户PyQt5和Qt的版本兼容性,以及可能的依赖问题,比如是否需要安装其他包如SIP。PyQt5通常需要先安装SIP,但pip可能会自动处理。 还有,用户可能遇到的常见错误,比如找不到合适的版本,这时候需要建议他们使用特定的pip命令,或者从第三方仓库下载。比如,推荐使用PyPI的镜像,或者Christoph Gohlke的库,如果官方源没有合适的版本。 最后,确保步骤清晰,分点列出,方便用户一步步操作。可能包括检查Python版本、升级pip、使用正确的安装命令、处理依赖等。同时,给出验证安装是否成功的方法,比如运行一个简单的PyQt5程序。 需要避免错误的信息,比如确认PyQt5是否支持Python 3.7。根据查阅资料,PyQt5 5.15及更高版本可能需要Python 3.6.1以上,但Python 3.7应该兼容。但某些最新版本可能不再支持3.7,所以建议安装稍旧的稳定版本。 总结,回答应该包括:安装方法、版本选择、常见问题解决、验证步骤。可能需要分步骤说明,并给出示例命令。</think>以下是针对Python 3.7安装PyQt5的完整指南: --- ### 安装方法及版本选择 PyQt5 5.15.x系列是最后一个官方支持Python 3.7的版本(2023年后新版本可能不再支持),推荐按以下流程操作: #### 1. 验证Python环境 ```bash python --version # 必须显示 3.7.x python -c "import platform; print(platform.architecture())" # 确认32/64位 ``` #### 2. 指定兼容版本安装 ```bash # 安装最后一个明确支持3.7的稳定版本 pip install PyQt5==5.15.9 --user ``` #### 3. 如果报错找不到版本 通过wheel文件手动安装: 1. 访问[Unofficial Windows Binaries](https://www.lfd.uci.edu/~gohlke/pythonlibs/#pyqt5) 2. 下载对应版本: `PyQt5‑5.15.9‑cp37‑cp37m‑win_amd64.whl`(64位) `PyQt5‑5.15.9‑cp37‑cp37m‑win32.whl`(32位) 3. 安装命令: ```bash pip install 下载路径/PyQt5‑5.15.9‑cp37‑cp37m‑win_amd64.whl ``` --- ### 常见问题解决 #### 问题1:`No matching distribution found` **解决方案**: 通过清华镜像源安装: ```bash pip install PyQt5==5.15.9 -i https://pypi.tuna.tsinghua.edu.cn/simple ``` #### 问题2:`Failed building wheel for PyQt5` **解决方案**: 安装编译依赖: ```bash # Windows pip install sip # Linux/macOS sudo apt-get install python3-dev qt5-default qttools5-dev-tools ``` --- ### 版本兼容性对照表 | Python版本 | 可用PyQt5版本 | 备注 | |------------|---------------------|-------------------------------| | 3.7 | ≤5.15.9 | 最后官方支持版本 | | 3.8+ | ≥5.15.10 | 需要新的Qt库 | --- ### 验证安装 创建`test.py`: ```python import sys from PyQt5.QtWidgets import QApplication, QLabel app = QApplication(sys.argv) label = QLabel("PyQt5安装成功!") label.show() sys.exit(app.exec_()) ``` 运行验证: ```bash python test.py ``` --- **注意**:自2020年起PyQt5官方仅提供商业版更新,开源用户建议考虑[PyQt6](https://www.riverbankcomputing.com/software/pyqt/)(需Python≥3.7)或[PySide6](https://wiki.qt.io/Qt_for_Python)(Qt官方维护)
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值