0

0

c++如何与Python交互 c++ pybind11框架使用【教程】

冰火之心

冰火之心

发布时间:2025-12-25 09:13:03

|

506人浏览过

|

来源于php中文网

原创

pybind11是轻量易用的c++/python绑定库,支持函数导出、stl类型自动转换、numpy零拷贝及跨平台构建,无需python c api知识。

c++如何与python交互 c++ pybind11框架使用【教程】

用 C++ 写高性能模块,再用 Python 调用,是工业级项目的常见做法。Pybind11 是目前最轻量、易上手且功能完备的 C++/Python 绑定库,无需 Python C API 底层知识,编译即用。

一、安装与最小可运行示例

推荐用 pip 安装 pybind11(头文件库,无运行时依赖):

pip install pybind11

写一个最简 C++ 函数并暴露给 Python:

// example.cpp
#include <pybind11/pybind11.h>
<p>int add(int a, int b) {
return a + b;
}</p><p>PYBIND11_MODULE(example, m) {
m.doc() = "pybind11 example plugin";
m.def("add", &add, "A function that adds two integers");
}

用 pybind11 提供的 setup.py 编译(需已安装 C++ 编译器,如 g++/MSVC):

立即学习Python免费学习笔记(深入)”;

from pybind11.setup_helpers import Pybind11Extension
from setuptools import setup
<p>ext_modules = [
Pybind11Extension("example", ["example.cpp"]),
]</p><p>setup(
name="example",
ext_modules=ext_modules,
)

终端执行:python setup.py build_ext --inplace,生成 example.cpython-*.so(Linux/macOS)或 .pyd(Windows)文件,即可在 Python 中导入使用:

import example
print(example.add(3, 4))  # 输出:7

二、传递复杂类型:std::vector、字符串、类对象

pybind11 自动支持常见 STL 类型转换(需包含对应头文件):

FaceSwapper
FaceSwapper

FaceSwapper是一款AI在线换脸工具,可以让用户在照片和视频中无缝交换面孔。

下载
  • std::vector → Python list(双向自动转换)
  • std::string ↔ str(UTF-8 安全)
  • C++ class 可绑定为 Python 类,支持构造、方法、属性、运算符重载

示例:绑定一个带成员函数的类:

class Pet {
public:
    Pet(const std::string &name) : name_(name) {}
    void set_name(const std::string &n) { name_ = n; }
    const std::string &get_name() const { return name_; }
private:
    std::string name_;
};
<p>PYBIND11<em>MODULE(pet, m) {
pybind11::class</em><Pet>(m, "Pet")
.def(pybind11::init<const std::string&>())
.def("set_name", &Pet::set_name)
.def("get_name", &Pet::get_name);
}

Python 端调用:

from pet import Pet
p = Pet("Milo")
p.set_name("Luna")
print(p.get_name())  # Luna

三、处理 NumPy 数组(高效数据交换)

科学计算场景下,避免拷贝大数组是关键。pybind11 支持零拷贝访问 NumPy 数组:

  • 需安装 numpy 并在 C++ 中 #include
  • pybind11::array_t 接收数组,通过 .data() 获取原始指针
  • 支持 shape、stride、dtype 检查,确保内存布局安全

示例:对 float32 数组做原地加法:

void add_one(pybind11::array_t<float> arr) {
    auto buf = arr.request();
    float *ptr = static_cast<float *>(buf.ptr);
    for (size_t i = 0; i < buf.size; ++i) {
        ptr[i] += 1.0f;
    }
}
<p>// 绑定
m.def("add_one", &add_one);

Python 端传入 numpy.ndarray 即可,底层不复制内存。

四、构建与跨平台注意事项

pybind11 本身是纯头文件库,但构建仍需注意:

  • Linux/macOS 默认用系统 clang/g++;Windows 推荐 MSVC 2019+ 或 Clang-cl
  • 若项目已有 CMake,直接用 find_package(pybind11 REQUIRED),更稳定可控
  • 发布时,扩展模块需与目标 Python 版本 ABI 兼容(建议用 auditwheeldelvewheel 修复依赖)
  • 调试崩溃时,开启 -g 编译选项,并用 gdb python -c "import yourmod" 定位 C++ 层问题

不复杂但容易忽略:确保 Python 解释器与编译时链接的 libpython 一致(尤其在 conda/virtualenv 多环境时)。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

373

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

434

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

801

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

370

2025.07.23

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

594

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

105

2025.10.23

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1564

2023.10.24

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.4万人学习

Git 教程
Git 教程

共21课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号