c/c++封装成python包

参考网址:https://blog.csdn.net/tiankongtiankong01/article/details/80420033

SWIG (Simplified Wrapper and Interface Generator) 是用来为C和C++程序构造脚本语言接口的软件开发工具。SWIG 实际上是一个编译器,获取C/C++的声明,用一个壳包起来,以便通过其他语言访问这些声明。因此,SWIG 最大的好处就是将脚本语言的开发效率和 C/C++ 的运行效率结合起来。
一:准备源文件
文件1:EncryptTool.h
int EncryptFile(const char *szInputFile, const char *szOutputFile);
int DecryptFile(const char *szInputFile, const char *szOutputFile);
文件2:EncryptTool.cpp   # 属于文件1的引用文件或者说是依赖包,后面动态链接将其封装起来
#include <iostream>
 
using namespace std;

int EncryptFile(const char *szInputFile, const char *szOutputFile)
{
   char str[] = "jiami";
 
   cout << "this is  : " << str << endl;
}

int DecryptFile(const char *szInputFile, const char *szOutputFile)
{
   char str[] = "解密函数";
 
   cout << "我是  : " << str << endl;
}
二:编写接口文件
文件3:EncryptTool.i(接口文件)
%module EncryptTool  (定义模块名)
%{
#define SWIG_FILE_WITH_INIT
#include "EncryptTool.h"  
%}
%include "EncryptTool.h"  # 导入源文件
1.%module后面的名字是被封装的模块名称,Python通过这个名称加载程序。
2.%{...%}之间所添加的内容,一般包含此文件需要的一些函数声明和头文件。
3.最后一部分,声明了要封装的函数和变量。
三:封装代码
swig -python -c++ EncryptTool.i

四:生成动态链接库 setup.py文件
from distutils.core import setup, Extension

#生成一个扩展模块
pht_module = Extension('_EncryptTool', #swig模块引用的模块名称,必须要有下划线
                        sources=['EncryptTool_wrap.cxx', #封装后的接口文件
                                 'EncryptTool.cpp',  #原始代码所依赖的文件
                                ],
                      )

setup(name = 'EncryptTool',    #打包后的名称,也是我们python导包的名字
        version = '0.1',  # 版本号
        author = 'SWIG Docs',  # 封装作者
        description = 'Simple swig pht from docs',  # 描述信息
        ext_modules = [pht_module], #与上面的扩展模块名称一致
        py_modules = ['EncryptTool'], #需要打包的模块列表
    )

五:安装到我们的python环境中
安装python3环境中:sudo python3 setup.py install
安装python2环境中:sudo python setup.py install

 

posted @ 2019-12-12 13:53  OldELeven  阅读(3351)  评论(0编辑  收藏  举报