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 类型转换(需包含对应头文件):

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

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

一点PPT
一点PPT

一句话生成专业PPT,AI自动排版配图

下载
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/numpy.h>
  • pybind11::array_t<float> 接收数组,通过 .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

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的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包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

437

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、保存并关闭文件即可。

803

2024.12.23

python升级pip
python升级pip

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

371

2025.07.23

string转int
string转int

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

1031

2023.08.02

css中float用法
css中float用法

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

595

2024.04.28

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

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

108

2025.10.23

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

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

1567

2023.10.24

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共48课时 | 10.6万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

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

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