怎么用CAPL与Python交互

怎么用CAPL与其他应用程序交互

  1. 怎么用CAPL与Python交互

怎么用CAPL与Python交互

  • 怎么用CAPL与其他应用程序交互
  • 前言
  • 1、CAPL怎么调Python?
    • 1.1CAPL调Python的命令
    • 1.2CAPL调用Python实例
  • 2、怎么把python运行的结果返回给CAPL
    • 2.1通过环境变量
  • 3、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_portsdef 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_portsdef 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,转换成数字7print("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_Setdef 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,转换成数字7canoe.set_System_var("Python_Result","Result_Value",Return_Value)#把转换后的COM号,通过环境变量给到Canoeif __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_Setdef 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号,通过环境变量给到Canoeif __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 sysdef 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)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/6566.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

我们的手机是如何连接上网的?骨干网又是什么?

什么是骨干网&#xff08;Backbone Network&#xff09; 几台计算机连接起来&#xff0c;互相可以看到其他人的文件&#xff0c;这叫局域网。整个城市的计算机都连接起来&#xff0c;就是城域网。把城市之间连接起来的网就叫骨干网。 这些骨干网是国家批准的可以直接和国外连…

环形列表 题目分析

一、题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 二、思路 1.使用快慢指针&#xff0c;快指针一次走两步&#xff0c;慢指针一次走一步&#xff0c;二者相对速度为1 2.当慢指针刚好进入环时&#xff0c;设二者的相对距离为N 3.如果链表中存在环&#xff…

Colab - Introduction to Object Detection using TensorFlow Hub

Colab - Introduction to Object Detection using TensorFlow Hub 1. 源由2. TensorFlow Hub3. 目标检测3.1 举例 - EfficientDet/D4 COCO 20173.2 下载示例图像3.2.1 显示部分样本3.2.2 定义一个将类别ID映射到类别名称和颜色的字典 3.3 加载模型3.4 单张照片执行推理3.4.1 推…

Python基础详解一

一&#xff0c;print打印 print("hello word") print(hello word) 双引号和单引号都可以 二&#xff0c;数据类型 Python中常用的有6种值的类型 输出类型信息 print(type(11)) print(type("22")) print(type(22.2)) <class int> <class str&…

n-Track Studio Suite for Mac激活版:打造您的专属音频工作室

n-Track Studio Suite for Mac是一款功能强大的数字音频工作站软件&#xff0c;让您在家中就能享受到专业录音棚的待遇。无论是录制人声、乐器还是MIDI序列&#xff0c;都能轻松应对。 n-Track Studio Suite for Mac激活版下载 这款软件拥有实时音高校准、时间拉伸和自动补足功…

深度学习500问——Chapter08:目标检测(7)

文章目录 8.3.8 RFBNet 8.3.9 M2Det 8.3.8 RFBNet RFBNet有哪些创新点 1. 提出RF block&#xff08;RFB&#xff09;模块 RFBNet主要想利用一些技巧使得轻量级模型在速度和精度上达到很好的trade-off的检测器。灵感来自人类视觉的感受野结构Receptive Fields&#xff08;RFs…

快速构建vscode pytest 开发测试环境

如果不想用 heavy 的pycharm vscode 也是1个很好的选择 安装python SDK pacman -S python [gatemanmanjaro-x13 tmp]$ pacman -Q python python 3.11.8-1安装Vscode 很多中方法 yay -S visual-studio-code-bin [gatemanmanjaro-x13 tmp]$ pacman -Q | grep -i visual visua…

[Java EE] 多线程(七): 锁策略

&#x1f338;个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 &#x1f3f5;️热门专栏:&#x1f355; Collection与数据结构 (90平均质量分)https://blog.csdn.net/2301_80050796/category_12621348.html?spm1001.2014.3001.5482 &#x1f9c0;Java …

基于MQTT通信开发的失物招领小程序

项目架构设计 这个项目采用前后端分离的方式&#xff0c;重新设计了两条链路来支撑程序的信息获取和传递 前端的小程序页面再启动页面渲染时&#xff0c;直接通过DBAPI从后端数据库获取信息&#xff0c;直接渲染在小程序中项目中给DBAPI的定位是快速从后端获取信息&#xff0…

SQL:NOT IN与NOT EXISTS不等价

在对SQL语句进行性能优化时&#xff0c;经常用到一个技巧是将IN改写成EXISTS&#xff0c;这是等价改写&#xff0c;并没有什么问题。问题在于&#xff0c;将NOT IN改写成NOT EXISTS时&#xff0c;结果未必一样。 目录 一、举例验证二、三值逻辑简述三、附录&#xff1a;用到的S…

【Flask 系统教程 5】视图进阶

类视图 在 Flask 中&#xff0c;除了使用函数视图外&#xff0c;你还可以使用类视图来处理请求。类视图提供了一种更为结构化和面向对象的方式来编写视图函数&#xff0c;使得代码组织更清晰&#xff0c;并且提供了更多的灵活性和可扩展性。 创建类视图 要创建一个类视图&am…

SVM直观理解

https://tangshusen.me/2018/10/27/SVM/ https://www.bilibili.com/video/BV16T4y1y7qj/?spm_id_from333.337.search-card.all.click&vd_source8272bd48fee17396a4a1746c256ab0ae SVM是什么? 先来看看维基百科上对SVM的定义: 支持向量机&#xff08;英语&#xff1a;su…

使用Python实现二维码生成工具

二维码的本质是什么&#xff1f; 二维码本质上&#xff0c;就是一段字符串。 我们可以把任意的字符串&#xff0c;制作成一个二维码图片。 生活中使用的二维码&#xff0c;更多的是一个 URL 网址。 需要用到的模块 先看一下Python标准库&#xff0c;貌似没有实现这个功能的…

一文了解python机器学习Sklearn

1.3 安装和配置Sklearn 要使用Sklearn库&#xff0c;首先需要安装Python和相应的库。在本教程中&#xff0c;我们将使用Python 3.x版本。可以使用以下命令安装Sklearn库&#xff1a; pip install scikit-learn安装完成后&#xff0c;可以在Python代码中导入Sklearn库&#xf…

code-server容器webpack的ws无法连接解决方法

TLDR 通过指定client的wsrul去连接ws devServer.client.webSocketURL ‘wss://<Forwarded uri>/ws’ 拓扑 1、code-server: 用于编写代码、启动webpack dev-server 服务&#xff1b;[https://<domain>:8001] 2、webpack: 用于浏览dev-server服务&#xff1b;[ht…

在视频中使用时间卷积和半监督训练进行三维人体姿态估计

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 摘要Abstract文献阅读&#xff1a;在视频中使用时间卷积和半监督训练进行三维人体姿态估计1、文献摘要2、提出方法2.1、时间扩张卷积模型2.2、半监督方法2.3、与传统…

UE4 Widget制作搜索框

效果&#xff1a; 一、控件层级结构 1.父控件层级结构 2.子控件层级结构 二、蓝图 1.先清除掉创建子项&#xff08;注意&#xff1a;这里使用的是reverse循环&#xff01;&#xff09; 2.判断是否含有关键字&#xff0c;创建子控件

【Android学习】日期和时间选择对话框

实现功能 实现日期和时间选择的对话框&#xff0c;具体效果可看下图(以日期为例) 具体代码 1 日期对话框 1.1 xml <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android&quo…

AGI要闻:斯坦福李飞飞首次创业,瞄准“空间智能”;OpenAI下周发布搜索产品挑战谷歌;新的开源 AI 眼镜来了|钛媒体AGI | 最新快讯

多方消息证实&#xff0c;OpenAI将会在北京时间5月10日&#xff08;周五&#xff09;凌晨2点公布搜索引擎新产品消息。 斯坦福大学首位红杉讲席教授 李飞飞 通用人工智能&#xff08;AGI&#xff09;领域又公布了一系列重磅消息。 5月4日凌晨&#xff0c;据路透社&#xff0c…

【深度学习】位置编码

一、引言 Self-Attention并行的计算方式未考虑输入特征间的位置关系&#xff0c;这对NLP来说是不可接受的&#xff0c;毕竟一个句子中每个单词都有着明显的顺序关系。Transformer没有RNN、LSTM那样的顺序结构&#xff0c;所以Transformer在提出Self-Attention的同时提出了Posi…