0

0

C++如何调用Python脚本_C++与Python混合编程环境配置

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-12-21 12:48:08

|

938人浏览过

|

来源于php中文网

原创

C++调用Python脚本可通过Python C API实现,首先安装Python开发环境并配置头文件与库路径,然后在C++代码中使用Python.h初始化解释器、执行Python语句或脚本,编译时链接Python库,注意版本和路径匹配,可进一步通过PyObject传递参数与获取返回值以实现数据交互。

c++如何调用python脚本_c++与python混合编程环境配置

在C++项目中调用Python脚本,可以借助Python官方提供的C API实现混合编程。这种方式适用于需要利用Python丰富的库(如NumPy、Pandas、机器学习模型)同时保持C++高性能计算能力的场景。以下是配置和调用的基本流程。

1. 安装Python开发环境

确保系统已安装Python,并且包含头文件和静态库。推荐使用Python 3.x版本。

  • Windows:建议使用Anaconda或直接从python.org下载安装,勾选“Add to PATH”和“Install for all users”,并确认安装了python-dev或类似组件。
  • Linux(Ubuntu/Debian):
    sudo apt-get install python3-dev python3-pip
  • macOS:通常自带Python环境,也可通过Homebrew安装完整开发包:
    brew install python

记录Python安装路径,例如:/usr/include/python3.8/C:\Python39\include

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

2. 配置C++编译环境

在C++项目中链接Python解释器,需指定头文件路径和库文件。

示例代码(main.cpp):

#include <Python.h>
#include <iostream>
<p>int main() {
// 初始化Python解释器
Py_Initialize();</p><pre class="brush:php;toolbar:false;">if (!Py_IsInitialized()) {
    std::cerr << "Failed to initialize Python" << std::endl;
    return -1;
}

// 执行一个简单的Python语句
PyRun_SimpleString("print('Hello from Python!')");

// 调用外部Python脚本
FILE* fp = fopen("test.py", "r");
if (fp) {
    PyRun_SimpleFile(fp, "test.py");
    fclose(fp);
} else {
    std::cerr << "Cannot open Python script: test.py" << std::endl;
}

// 关闭Python解释器
Py_Finalize();
return 0;

}

准备Python脚本(test.py):

有道智云AI开放平台
有道智云AI开放平台

有道智云AI开放平台

下载
import sys
print("Running test.py")
x = 10
y = 20
print(f"Sum: {x + y}")

3. 编译与链接

使用g++或其他编译器时,必须链接Python库。

  • Linux/macOS 示例命令:
    g++ main.cpp -o run_py \`python3-config --includes --libs\`
    或明确指定路径:
    g++ main.cpp -I/usr/include/python3.8 -lpython3.8 -o run_py
  • Windows(MinGW + Python):
    g++ main.cpp -I"C:\Python39\include" -L"C:\Python39\libs" -lpython39 -o run_py.exe

注意:Windows下可能因运行库不匹配导致运行时报错,建议使用与Python相同架构(32/64位)的编译器。

4. 常见问题与调试技巧

  • 找不到Python.h:检查-I路径是否正确指向Python的include目录。
  • 链接错误(undefined reference):确认-lpythonXX中的版本号与当前Python一致。
  • 运行时报错无法加载Python DLL:将Python安装路径(如C:\Python39)加入系统PATH。
  • 中文路径或空格问题:避免脚本路径含空格或非ASCII字符。

可通过python3-config --includes--libs查看实际编译参数。

5. 进阶:传递参数与获取返回值

除了执行脚本,还可通过PyObject操作变量和函数。

PyRun_SimpleString("result = 3 * 4");
PyObject* global_dict = PyModule_GetDict(PyImport_AddModule("__main__"));
PyObject* result_obj = PyDict_GetItemString(global_dict, "result");
long result = PyLong_AsLong(result_obj);
std::cout << "Result from Python: " << result << std::endl;

这允许更精细的数据交互,比如传入C++变量给Python处理,再取回结果。

基本上就这些。只要环境配置正确,C++调用Python脚本并不复杂,但要注意版本匹配和路径设置。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

78

2025.12.04

Python 数据清洗与预处理实战
Python 数据清洗与预处理实战

本专题系统讲解 Python 在数据清洗与预处理中的核心技术,包括使用 Pandas 进行缺失值处理、异常值检测、数据格式化、特征工程与数据转换,结合 NumPy 高效处理大规模数据。通过实战案例,帮助学习者掌握 如何处理混乱、不完整数据,为后续数据分析与机器学习模型训练打下坚实基础。

32

2026.01.31

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6468

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3336

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

1665

2025.12.25

常见的编码方式
常见的编码方式

常见的编码方式有ASCII编码、Unicode编码、UTF-8编码、UTF-16编码、GBK编码等。想了解更多编码方式相关内容,可以阅读本专题下面的文章。

647

2023.10.24

a和A对应的ASCII码数值
a和A对应的ASCII码数值

a的ascii码是65,a的ascii码是97;ascii码表中,一个字母的大小写数值相差32,一般知道大写字母的ascii码数值,其对应的小写字母的ascii码数值就算出来了,是大写字母的ascii码数值“+32”。想了解更多相关的内容,可阅读本专题下面的相关文章。

2249

2024.10.24

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1496

2023.07.26

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.1万人学习

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

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