Python + C/C++ 嵌入式编程(2):基于Code::Blocks进行环境配置和开发(入门版)

本文详细介绍了如何在Code::Blocks中配置Python+C/C++混合编程环境,特别是针对使用Anaconda和Tensorflow框架的环境设定。文中强调了Py_SetPythonHome函数的重要性和配置Python环境变量的步骤,并提供了关键代码片段,帮助读者理解和避免配置过程中的常见问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

因为最近在忙着毕业论文的事情(感伤一下 : 要毕业离开厦大了,呜呜!!!),所以一直没有时间来补充这部分的内容,现在才抽出时间来继续写这个系列的博文。前一篇博文在写的时候没有考虑到一些细节的因素,可能许多读者要把代码运行起会遇到许多的困难,所以这一篇博文将就代码里面的细节和具体环境配置再详细地给大家讲一遍,希望对大家能够提供一定帮助。(ps: 毕业前应该会把这部分的工作整理到GitHub上,敬请期待咯……)

目录

  • 环境配置
  • 代码细节
  • 注意事项
  • 总结

环境配置

对于使用C/C++来调用Python代码,优势不言而喻啦,不需要把C/C++代码进行反复编译成动态链接或者静态链接的库,然后使用Python进行调用(ps:反正我们觉得好,哈哈哈)。好了,废话不多说,进入正题。对于环境的配置,我们首先要选取好我们的Python环境,我喜欢用Anaconda2来管理我的Python环境,这个全家桶还是很棒的,尤其对于我这种强迫症患者,喜欢每个Python环境井井有条的,所以只好和Linux的系统Python说拜拜咯,不喜欢把各种深度框架装在一起,在一起,一起, 起……。

这里我选取的是Python环境选取的是Anaconda2中tensorflow框架下的环境,这是因为我要用到tensorflow深度框架,这不多说了,直接上图:
配置Python的头文件路径
因为用到了numpy里面的PyArrayObject这个对象,所以这里需要加入numpy/core/include路径。

然后下一步我们需要加入python环境变量的lib文件:
配置Python的lib文件路径

最后配置相应的lib文件即可:
lib文件配置
这样就配置好了我们的开发环境,下面就是写代码阶段了,由于第一篇博客已经对代码进行了较为详细的介绍,这里只突出一些细节就好了。


代码细节

这是要被调用的Python代码,这一块没什么好说的了,一些简单的矩阵和List的处理。

import numpy as np

class Multiply(object):

    def __init__(self, a, b):

        self.a = a
        self.b = b

    def multiply(self):

        self.c = self.a * self.b

    def ShowResult(self):

        print("Result:" + str(self.c))


def FuncCallEntrance():

    A = Multiply(5, 3)
    A.multiply()
    A.ShowResult()

    B = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
    B = np.asarray(B, dtype='float')
    C = [[1], [2], [3]]
    C = np.asarray(C, dtype='float')

    print B.shape, C.shape
    D = np.dot(B, C)

    print D
    return D

def ArrayListReturn():

    ArrList = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值