python中调用 C#动态链接库问题记录

Python013

python中调用 C#动态链接库问题记录,第1张

程序[摘自 https://blog.csdn.net/LTG01/article/details/80700513 ] 

import clr

clr.FindAssembly("PythonNetTest.dll") ## 加载c#dll文件

from PythonNetTest import *# 导入命名空间

instance = Class1() #class1是dll里面的类

print(instance.AddShort(2, 3))#一个简单的加法

instance.ShowForm()

【1】报错: AttributeError: 'module' object has no attribute 'FindAssembly'

错误原因:

python存在 clr 模块,python的pythonnet模块中,也存在clr,在import 过程中,

要用的是后者中的clr,因此要利用 pip uninstall clr

把clr模块卸载掉,再运行上面的程序就可以了。

【2】 报错: name "PythonNetTest" has not found

错误原因:

未将PythonNetTest.dll与.py程序,放在同一个目录下,放在同一个目录下即可。

二、Python调用C/C++\x0d\x0a\x0d\x0a\x0d\x0a1、Python调用C动态链接库\x0d\x0a\x0d\x0aPython调用C库比较简单,不经过任何封装打包成so,再使用python的ctypes调用即可。\x0d\x0a(1)C语言文件:pycall.c\x0d\x0a\x0d\x0a[html] view plain copy \x0d\x0a/***gcc -o libpycall.so -shared -fPIC pycall.c*/ \x0d\x0a#include \x0d\x0a#include \x0d\x0aint foo(int a, int b) \x0d\x0a{ \x0d\x0a printf("you input %d and %d\n", a, b) \x0d\x0a return a+b \x0d\x0a} \x0d\x0a(2)gcc编译生成动态库libpycall.so:gcc -o libpycall.so -shared -fPIC pycall.c。使用g++编译生成C动态库的代码中的函数或者方法时,需要使用extern "C"来进行编译。\x0d\x0a(3)Python调用动态库的文件:pycall.py\x0d\x0a\x0d\x0a[html] view plain copy \x0d\x0aimport ctypes \x0d\x0all = ctypes.cdll.LoadLibrary \x0d\x0alib = ll("./libpycall.so")\x0d\x0alib.foo(1, 3) \x0d\x0aprint '***finish***' \x0d\x0a(4)运行结果:\x0d\x0a\x0d\x0a\x0d\x0a2、Python调用C++(类)动态链接库 \x0d\x0a\x0d\x0a 需要extern "C"来辅助,也就是说还是只能调用C函数,不能直接调用方法,但是能解析C++方法。不是用extern "C",构建后的动态链接库没有这些函数的符号表。\x0d\x0a(1)C++类文件:pycallclass.cpp\x0d\x0a\x0d\x0a[html] view plain copy \x0d\x0a#include \x0d\x0ausing namespace std \x0d\x0a \x0d\x0aclass TestLib \x0d\x0a{ \x0d\x0apublic: \x0d\x0avoid display() \x0d\x0avoid display(int a) \x0d\x0a} \x0d\x0avoid TestLib::display() { \x0d\x0acout \x0d\x0ausing namespace std \x0d\x0aint test() \x0d\x0a{ \x0d\x0aint a = 10, b = 5 \x0d\x0areturn a+b \x0d\x0a} \x0d\x0aint main() \x0d\x0a{ \x0d\x0acout \x0d\x0a#include \x0d\x0a#include \x0d\x0a \x0d\x0aint fac(int n) \x0d\x0a{ \x0d\x0aif (n 回答于 2022-11-16

# coding=GBK

from ctypes import *

import time

if __name__ == '__main__':

time_begin = time.clock()

#dll = CDLL("d.dll")# 加载dll方式一

dll = cdll.LoadLibrary("d.dll") # 加载dll方式二

print(dll.add(2, 6))# 调用dll中add方法

dll.print_sum(100) # 调用dll中print_sum方法

t = time.clock() - time_begin # 计算时间差

print("Use time: %f" %t)# 打印耗时时间