神刀安全网

Windows平台下Python使用swig调用C++


步骤0:swig简介

swig是一种可以将C++代码转换为多种脚本语言封装的工具,可以在swig官网www.swig.org下载,解压后将swig.exe的路径添加到环境变量path中即可使用swig

步骤1:准备C++代码

编写需要在Python中调用的C++代码,最好将函数和类的声明统一放到头文件中,函数和类的实现放到源文件中

C++头文件

头文件主要包括:

  • #include调用(例如#include <iostream>
  • 命名空间指定using namespace std;
  • 函数和类的声明
#include <iostream> using namespace std;  class example {     private:         int num;     public:         void say_hello(void);         void change(int din);         int get_num(); }; 

C++源文件

源文件为头文件中函数和类的实现

#include "example.h"  void example::say_hello(void) {     cout << "hello python,I am C++" << endl; }  void example::change(int din) {     num = din; }  int example::get_num(void) {     return num; } 

步骤二:使用swig封装

编写封装说明文件

swig封装需要一个.i后缀文件的封装说明,其中

  • %module <name>为封装名称,Python调用的包名就是<name>
  • %{...%}为附加的函数说明和头文件,源文件以外的部分都要包括在这里,包括头文件和宏定义等
  • 之后为要封装的函数或类,可以直接引用头文件(若已经将要封装的部分的声明写在头文件中)
%module Example_swig  %{ #include "example.h" %}  %include "example.h" 

调用swig封装

在命令行中输入swig -python -c++ <swig_config>.i,其中<swig_config>.i为上面写的说明文件

swig -python -c++ example.i 

调用后生成两个文件:

  • <cpp_source>_wrap.cxx文件
  • <name>.py文件

步骤三:使用VS编译

安装VC140编译器

python3.5使用的编译器是VC140编译器,对应版本是VS2015,本次使用的是VS2017使用VC141编译器。需要在VS2017中安装VC140编辑器,可以直接在工具->获取工具和功能中安装

配置VS编译环境

在C++的空工程基础上建立环境

配置输出类型

生成->配置管理器中设置:

  • 活动解决方案配置Release
  • 活动解决方案平台X64(本机为64位机)
Windows平台下Python使用swig调用C++

配置输出

引入Python库(关键)

项目->属性中配置Python的库

  • VC++目录中的包含目录中,导入Python安装路径下的include路径(包含Python.h)
  • 链接器->常规附加库目录中,导入Python安装路径下的libs路径(注意不是Lib路径,包括dll文件)
Windows平台下Python使用swig调用C++

配置头文件

Windows平台下Python使用swig调用C++

配置库

编译输出

选择生成->生成解决方案,在X64->Release文件夹下有一个dll文件,即为编译输出的动态链接库。将其名称改为_<name>.pyd(本例中为_Example_swig.pyd),将其与swig生成的<name>.py文件放在同一目录中

步骤四:测试调用

在python,使用import <name>即可调用刚才生成的包(同一目录下)

import Example_swig  a = Example_swig.example() a.say_hello()  a.change(3) print(a.get_num()) 
hello python,I am C++ 3 [Finished in 0.2s] 

转载本站任何文章请注明:转载至神刀安全网,谢谢神刀安全网 » Windows平台下Python使用swig调用C++

分享到:更多 ()

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址