Python调用.net动态库实现过程解析


Posted in Python onJune 05, 2020

pythonnet简介

  • pythonnet是cpython的扩展
  • pythonnet提供了cpython和.net程序集之间交互的桥梁
  • pythonnet开源在github上

pythonnet安装

通过pip install pythonnet安装

pythonnet的使用帮助

pythonnet的使用帮助,请参见github.

pythonnet中的坑

cpython是分32和64位的,对应的pythonnet也是分的,版本要对应好
pythonnet最核心的就是python.Runtime.dll动态库,这个库是c#编写的实现了两种语言的交互

ref类型的参数如何返回

  • 返回值的第一个元素是c#的返回值
  • 返回值的第二个元素就是ref的值了,ref String[] 对应的返回值第二个元素就是元组tuple

如何加载动态库

# clr是公共运行时环境,该模块是与c#交互的核心
import clr
import sys
# 导入clr时这个模块最好也一起导入,这样可用使用AddReference()方法
import System

# input()

from System import Array
from System import String

# 打印当前.net运行时的版本
print(System.Environment.Version)

# 打印当前的环境变量
print('---------------------')
for p in sys.path:
  print(p)
print('---------------------')

# 加载动态,不要带动态库的后缀名,如果d=None,表示动态库没有找到
d = clr.FindAssembly('YctxKj.Card.Interpreter')
print(d)
# from后面跟的是动态库的名字,不是命名空间
from YctxKj.Card.Interpreter import *
d = clr.FindAssembly('YctxKj.Card.CardReader')
print(d)
from YctxKj.Card import CardReader

# 打印程序集,如果动态库加载成功,程序集里就会含有动态库的程序集
lt = clr.ListAssemblies(False)

for i in range(lt.Length):
  print('%d = %s' % (i,lt[i]))

ret = 0

# 程序调用业务代码
_reader = CardReader()
_Interpreter = ScriptInterpreter()
_Interpreter._reader = _reader
_Interpreter.Init();

ret = _Interpreter.SetKeyMode(305)
print('ret=%d' % ret)

arCarder = ''

# input() 可以程序暂停,然后使用vs附加进程python.exe调试
# input()
ret = _reader.ListReader(arCarder);
print('ret = %d' % ret[0])
print('ref param string[] length = %d' % ret[1].Length)
if ret[1].Length > 0:
  items = ret[1]

  for t in items:
    print(t)
else:
  print('don\'t find cardreader dev')
  exit()

# 链接读卡器
strReader = items[1]
strATR = ''
nRet = _reader.Connect(strReader, strATR)
if nRet[0] != 0:
  print('connect card fail, nRet=%d' % nRet[0])
  _reader.Beep()
  _reader.Beep()
  exit()

print('crd connect successed,atr=%s' % nRet[1])
_reader.Beep()
# 断开读卡器
_reader.Disconnect()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
学习python (2)
Oct 31 Python
Python自动重试HTTP连接装饰器
Apr 28 Python
django框架如何集成celery进行开发
May 24 Python
浅谈django orm 优化
Aug 18 Python
在python中利用numpy求解多项式以及多项式拟合的方法
Jul 03 Python
Python实现制度转换(货币,温度,长度)
Jul 14 Python
python+selenium select下拉选择框定位处理方法
Aug 24 Python
python基于K-means聚类算法的图像分割
Oct 30 Python
flask的orm框架SQLAlchemy查询实现解析
Dec 12 Python
Python日志处理模块logging用法解析
May 19 Python
python 提高开发效率的5个小技巧
Oct 19 Python
关于Numpy之repeat、tile的用法总结
Jun 02 Python
Python实现将元组中的元素作为参数传入函数的操作
Jun 05 #Python
Python Dict找出value大于某值或key大于某值的所有项方式
Jun 05 #Python
python3检查字典传入函数键是否齐全的实例
Jun 05 #Python
Python使用20行代码实现微信聊天机器人
Jun 05 #Python
Python并发请求下限制QPS(每秒查询率)的实现代码
Jun 05 #Python
Python爬虫爬取百度搜索内容代码实例
Jun 05 #Python
python3读取autocad图形文件.py实例
Jun 05 #Python
You might like
与空气斗智斗勇的经典《Overlord》,传说中的“无稽之谈”
2020/04/09 日漫
解析php中如何直接执行SHELL
2013/06/28 PHP
php简单的留言板与回复功能具体实现
2014/02/19 PHP
Netbeans 8.2将支持PHP7 更精彩
2016/06/13 PHP
php利用云片网实现短信验证码功能的示例代码
2017/11/18 PHP
PHP命令Command模式用法实例分析
2018/08/08 PHP
判断控件是否已加载完成的代码
2010/02/24 Javascript
jquery蒙版控件实现代码
2010/12/08 Javascript
js和php如何获取当前url的内容
2013/09/22 Javascript
使用AngularJS创建单页应用的编程指引
2015/06/19 Javascript
深入理解JavaScript中的并行处理
2016/09/22 Javascript
javascript实现去除HTML标签的方法
2016/12/26 Javascript
JavaScript 中定义函数用 var foo = function () {} 和 function foo()区别介绍
2018/03/01 Javascript
Bootstrap 中data-[*] 属性的整理
2018/03/13 Javascript
微信小程序可滑动周日历组件使用详解
2019/10/21 Javascript
vue中在vuex的actions中请求数据实例
2019/11/08 Javascript
jquery实现上传图片功能
2020/06/29 jQuery
[51:34]Ti4主赛事胜者组 DK vs EG 2
2014/07/19 DOTA
深入讲解Python函数中参数的使用及默认参数的陷阱
2016/03/13 Python
Python使用type关键字创建类步骤详解
2019/07/23 Python
python sklearn常用分类算法模型的调用
2019/10/16 Python
Python计算不规则图形面积算法实现解析
2019/11/22 Python
使用Python matplotlib作图时,设置横纵坐标轴数值以百分比(%)显示
2020/05/16 Python
华美博弈C/VC工程师笔试试题
2012/07/16 面试题
监理资料员岗位职责
2014/01/03 职场文书
动画设计系毕业生求职信
2014/07/15 职场文书
未婚证明书模板
2014/10/08 职场文书
党的群众路线教育实践活动对照检查剖析材料
2014/10/09 职场文书
老公写给老婆的检讨书
2015/05/06 职场文书
八月一日观后感
2015/06/10 职场文书
幼儿园小朋友毕业感言
2015/07/30 职场文书
办公室规章制度范本
2015/08/04 职场文书
2016年小学优秀班主任事迹材料
2016/02/29 职场文书
诉讼和解协议书
2016/03/23 职场文书
如何用python绘制雷达图
2021/04/24 Python
python使用openpyxl库读写Excel表格的方法(增删改查操作)
2021/05/02 Python