首页 > Python资料 博客日记
怎么用CAPL与Python交互
2024-09-21 05:00:05Python资料围观54次
怎么用CAPL与其他应用程序交互
- 怎么用CAPL与Python交互
怎么用CAPL与Python交互
前言
Python是很强大的胶水语言,学会了怎么用CAPL与Python交互,那CAPL就能做超级多的功能。
不要因为没用过Python放弃这么好的工具,因为Python用户太多了,你直接百度搜索想要Python实现什么功能,很多时候AI都帮你把Python代码写好了,拿来调试下就能用,关键是用过一次之后,可能就会发现打开了新世界的大门。
1、CAPL怎么调Python?
1.1CAPL调Python的命令
命令:sysExecCmd
//long sysExecCmd(char cmd[], char params[], char directory[]); // 帮助手册里可以搜到用法
sysExecCmd("python Find_Com_Index.py", "", "./");
这个命令就是调windows的CMD窗口去做操作,
第一个参数:char cmd[]
要执行的命令,也就是要通过CMD调的应用程序,可以是bat脚本,可以是某个exe程序,当然也可以是python了,如果是python,就可以后面接python要接的脚本Find_Com_Index.py
第二个参数:char params[]
这个是最有用的,就是调python脚本或者调别的exe,bat等入口参数
第三个参数
是这个命令的绝对路径,或者相对于工作目录的相对路径。如果是python的话,因为按照python的时候,已经给python配置好环境变量了,就是你在CMD窗口里输入python之后,CMD就会根据环境变量里配置的路径去找到python.exe执行文件调用,那这个时候路径这个参数就要填你要调用的脚本(.py)的路径。
python脚本的路径可以直接写全,绝对路径:“C:\Work\Demo”
但是每个人的工程存放路径不一致,建议还是用相对工程路径:“./“代表py脚本和canoe工程文件.cfg文件在同一个目录
如果你想在canoe工程文件.cfg文件目录下再建一个文件夹专门放py脚本就可以用”./Python_Script”
1.2CAPL调用Python实例
很多测试用例里都有Power ON/OFF或者调节电压的需求,比较便宜的程序控制电源都支持串口通信控制电源开关和电压。
CAPL可以调用内置函数RS232Send命令通过COM口发送命令,但是前提是需要通过RS232Open命令打开对应的COM口.针对自己的电脑,你的232串口插上之后可以通过设备管理器找到对应的COM口,然后在CAPL里配置,但是别人用你的脚本测试的时候可能COM口序列号就不一样了,每次都要重新修改,如果能用python找到COM号,那谁都能用你的脚本了。
用python寻找你电脑上插的232串口线的COM号就比较简单了,百度一搜一大堆,退一步讲,你从网上抄的python脚本一运行就报错,别怕,python用户多,你遇到的这点小问题,前人历经了N多遍,搜一下就能解决python报错了。
Python脚本如下:网上搜到的,先把电脑识别到的所有COM打印出来,看看长什么样子,再找自己想要的
import serial
import serial.tools.list_ports
def Get_Power_COM_Index():
ports_list = list(serial.tools.list_ports.comports())#找到所有的port口
if len(ports_list) <= 0:#一个也没找到就报错
print("there is no Serial Device")
else:
for comport in ports_list:
print(list(comport)[0], list(comport)[1])#有COM口就把所有的COM口信息打印出来
if __name__ == "__main__":
Get_Power_COM_Index()
CAPL代码:
on key 'a'
{
sysExecCmd("python Find_Com_Index.py", "", "./");//先不用输入参数,只是试验下调Python的效果
}
效果如下,假设电源的那根RS232线是COM7,其实我们运行这个脚本的最终目的就是要拿到这个‘7’,用这个7让CAPL打开7这个COM口:
那怎么拿到这个7, 我们可以用如果‘USB-to-Serial’这个字符串存在COM口信息里,就能获取到第4行的信息, 再把第4行按照空格分隔字符串,就能得到COM7,再把COM7里的COM删除调,就能拿到‘7’
Python:
import serial
import serial.tools.list_ports
def Get_Power_COM_Index():
ports_list = list(serial.tools.list_ports.comports())#找到所有的port口
if len(ports_list) <= 0:#一个也没找到就报错
print("there is no Serial Device")
else:
for comport in ports_list:
#print(list(comport)[0], list(comport)[1])#调试的时候打印,正式用的时候可打可不打了
if 'USB-to-Serial' in list(comport)[1]:#判断‘USB-to-Serial’这个字符串存在COM口信息里
COM_Channel = list(comport)[0]#在的话就把‘COM7’取出来
COM_Channel = COM_Channel.strip('COM')#把‘COM’字符串拿掉
Return_Value = int(COM_Channel)#把字符串7,转换成数字7
print("The useful USB Serial Port is :",Return_Value )
if __name__ == "__main__":
Get_Power_COM_Index()
这样我们就能拿到‘7’了
2、怎么把python运行的结果返回给CAPL
2.1通过环境变量
CAPL调python的命令:sysExecCmd的返回结果只是代表有没有成功执行这个命令,并不返回python运行后的结果。
目前没有找到更好的方法,用了绕一圈的方法:用Python调用Canoe把结果赋值给Canoe的环境变量,CAPL再取环境变量拿结果。
如果大家有更好的方法,欢迎留言。
Python怎么调用Canoe,在安装Canoe的时候,有范例,感兴趣可以研究下,我只抄了用到的一部分,路径如下(版本可能不一致):
先在Canoe里新建环境变量,不知道怎么建的可以搜一下
然后python里,
1.用python连接上canoe
2.获取到想要的COM的序列号
3.通过设置环境变量,把COM序列号赋值给Canoe环境变量:
import serial
import serial.tools.list_ports
import time, os, msvcrt
from win32com.client import *
from win32com.client.connect import *
class CanoeSync(object):
def __init__(self):
self.app = Dispatch('CANoe.Application')#打开Canoe
def set_System_var(self, Namespace, system_var, Value_Set):
if (self.app != None):
self.app.System.Namespaces(Namespace).Variables(system_var).Value = Value_Set
def Get_Power_COM_Index():
canoe = CanoeSync()#连接上Canoe,获取句柄,有了句柄之后就可以用canoe操作CanoeSync里定义的函数
ports_list = list(serial.tools.list_ports.comports())#找到所有的port口
if len(ports_list) <= 0:#一个也没找到就报错
print("there is no Serial Device")
else:
for comport in ports_list:
#print(list(comport)[0], list(comport)[1])#有COM口就把所有的COM口信息打印出来
if 'USB-to-Serial' in list(comport)[1]:#判断‘USB-to-Serial’这个字符串存在COM口信息里
COM_Channel = list(comport)[0]#在的话就把‘COM7’取出来
COM_Channel = COM_Channel.strip('COM')#把‘COM’字符串拿掉
Return_Value = int(COM_Channel)#把字符串7,转换成数字7
canoe.set_System_var("Python_Result","Result_Value",Return_Value)#把转换后的COM号,通过环境变量给到Canoe
if __name__ == "__main__":
Get_Power_COM_Index()
在CAPL里
1.按键’a’调用Python脚本去读COM序列号
2.去环境变量里拿COM序列号
3.。。。
on key 'a'
{
sysExecCmd("python Find_Com_Index.py", "", "C:\\Work\\Demo");
}
on sysvar_update Python_Result::Result_Value
{
write("Find Com Channel is: %d",@Python_Result::Result_Value);
}
CAPL的打印结果:
3、CAPL调Python的输入参数
如果调python的时候没有带输入参数,回有很大的不方便:
1.调一个python脚本实现一个功能,那一个CAPL脚本里,可能几十上百个调python的用的地方,总不能写几百个python脚本吧,就比如说这次是想用python找USB转串口的COM号,用的关键字是’USB-to-Serial’,那下一个case想找的是’Technology’的怎么办?
把想搜索的作为输入参数传进去:
CAPL:
on key 'b'
{
sysExecCmd("python Find_Com_Index.py", "Technology", "./");
}
python:把输入参数作为搜索条件
import serial
import serial.tools.list_ports
import time, os, msvcrt
from win32com.client import *
from win32com.client.connect import *
class CanoeSync(object):
def __init__(self):
self.app = Dispatch('CANoe.Application')#打开Canoe
def set_System_var(self, Namespace, system_var, Value_Set):
if (self.app != None):
self.app.System.Namespaces(Namespace).Variables(system_var).Value = Value_Set
def Get_Power_COM_Index(str):
canoe = CanoeSync()#连接上Canoe,获取句柄,有了句柄之后就可以用canoe操作CanoeSync里定义的函数
ports_list = list(serial.tools.list_ports.comports())#找到所有的port口
if len(ports_list) <= 0:#一个也没找到就报错
print("there is no Serial Device")
else:
for comport in ports_list:
#print(list(comport)[0], list(comport)[1])#有COM口就把所有的COM口信息打印出来
if str in list(comport)[1]:#判断str这个字符串存在COM口信息里
COM_Channel = list(comport)[0]#在的话就把‘COMx’取出来
COM_Channel = COM_Channel.strip('COM')#把‘COM’字符串拿掉
Return_Value = int(COM_Channel)#把字符串转换成数字
canoe.set_System_var("Python_Result","Result_Value",Return_Value)#把转换后的COM号,通过环境变量给到Canoe
if __name__ == "__main__":
CMD1 = sys.argv[1]
Get_Power_COM_Index(CMD1)
2,你想用python打开某个文件,写入某个值,操作的文件名,写入的数最好都是可以通过输入参数传进去的,而不是要写n多个python。多个参数的传入时,参数与参数之间,用空格代替。
CAPL:
on key 'c'
{
sysExecCmd("python test.py", "a.txt 12345", "./");
}
``
python
```python
import sys
def write_txt(filename,value):
with open(filename,'a') as f:
f.write(value)
if __name__ == "__main__":
CMD1 = sys.argv[1]
CMD2 = sys.argv[2]
write_txt(CMD1,CMD2)
标签:
相关文章
最新发布
- 【Python】selenium安装+Microsoft Edge驱动器下载配置流程
- Python 中自动打开网页并点击[自动化脚本],Selenium
- Anaconda基础使用
- 【Python】成功解决 TypeError: ‘<‘ not supported between instances of ‘str’ and ‘int’
- manim边学边做--三维的点和线
- CPython是最常用的Python解释器之一,也是Python官方实现。它是用C语言编写的,旨在提供一个高效且易于使用的Python解释器。
- Anaconda安装配置Jupyter(2024最新版)
- Python中读取Excel最快的几种方法!
- Python某城市美食商家爬虫数据可视化分析和推荐查询系统毕业设计论文开题报告
- 如何使用 Python 批量检测和转换 JSONL 文件编码为 UTF-8
点击排行
- 版本匹配指南:Numpy版本和Python版本的对应关系
- 版本匹配指南:PyTorch版本、torchvision 版本和Python版本的对应关系
- Python 可视化 web 神器:streamlit、Gradio、dash、nicegui;低代码 Python Web 框架:PyWebIO
- 相关性分析——Pearson相关系数+热力图(附data和Python完整代码)
- Python与PyTorch的版本对应
- Anaconda版本和Python版本对应关系(持续更新...)
- Python pyinstaller打包exe最完整教程
- Could not build wheels for llama-cpp-python, which is required to install pyproject.toml-based proj