python读取log文件_python分析log日志

python读取log文件_python分析log日志一、原理QXDM抓取log为isf格式,需要用QCAT打开进行分析,如果需要自动分析QXDM抓取的log,一个可行的方法为调用QCAT的COM接口打开isf文件并进行分析。QCAT6.X支持基于COM的接口调用,允许用户通过Perl、VBScript、JavaScript、Python等脚本语言调用应用。具体调用方法在QCAT安装后的《QCATUserGuide》用户手册中,第六章S…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

一、原理

QXDM抓取log为isf格式,需要用QCAT打开进行分析,如果需要自动分析QXDM抓取的log,一个可行的方法为调用QCAT的COM接口打开isf文件并进行分析。

QCAT 6.X支持基于COM的接口调用,允许用户通过PerlVBScript、JavaScript、Python等脚本语言调用应用。具体调用方法在QCAT安装后的《QCAT User Guide用户手册中,第六章Scripting with QCAT (Windows Only) 详述了QCAT COM编程可用的接口。

二、关键步骤

1、安装pywin32模块

如果要进行com编程需要安装pywin32模块才能进行COM调用

pip install pywin32

2、通过COM接口打开QCAT

import win32com.client

try:
    qcatApp = win32com.client.Dispatch("QCAT6.Application")
except :
    QMessageBox.warning(self, '', 'QCAT打开失败,请检查QCAT')
    sys.exit(1)

3、设置过滤器

self.TargetLogId = 0xB0C0   

SIBFilter = qcatApp.PacketFilter
SIBFilter.SetAll(False) #设置过滤所有的消息类型


SIBFilter.Set(self.TargetLogId, True)  #只显示类型为0xB0C0的log,可以设置多次filter显示不同类型LOG
SIBFilter.Commit()

4、打开UE LOG文件

if qcatApp.OpenLog(winfilepath) != 1:  #winfilepath为需要打开的文档路径
    print("Open Log Error")
    exit()
print("file open ok")

5、遍历UE LOG过滤后内容

QcatPacket = qcatApp.FirstPacket  #第一包

QcatPacket.Next() #下一包,如果已经是最后一包则该方法返回FALSE

QcatPacket.text #获取QCAT解码的内容

三、常见问题

由于调用QcatPacket.text获取QCAT解码的内容,然后通过文本处理的方式对log进行处理,语法上是对str进行处理,但是由于协议兼容性,有很多地方需要注意。

1、注意可选信元和信令

很多信元是可选的,因此需要先设置信元的默认值,然后判断需要解析的信元是否存在,如果没有解析出来则说明为默认值。

有些信令比如SIB2~8需要根据SIB1来判断是否存在,如果不存在则无需等待收集齐后处理。

对于SIB3、SIB5和SIB6等SIB处理,都含有cellReselectionPriority,需要判断每个cellReselectionPriority对应的频点,不可混淆,特别多个SIB在同一个周期调度时更需要注意。

2、兼容不同版本协议

比如同频重选门限对于R8为”s-IntraSearch “,对于R9为”s-IntraSearchP-r9″,由于”s-IntraSearchP-r9″包含了”s-IntraSearch”,为了避免R8和R9的参数混合了,这里需要在”s-IntraSearch”后面加一个空格,判断如果含有”s-IntraSearch “则为R8,如果含有”s-IntraSearchP-r9″则为R9。

自定义的内部信元更需要注意,比如“0xB193 LTE ML1 Serving Cell Meas Response”中,较早的终端SINR显示为“SINR Rx[0]”,有些较新的终端则显示为“SNR Rx[0]”,处理时统一根据“NR Rx[0]”来判断。

3、注意数据转换

有些信元的取值范围可以是数字,也可以是invalid或者infinity等,如果简单将str转换为int,会出现转化失败的情况,因此需要先通过str.isdigit()判断是否能转换为数字,然后再转换。

4、pywin32与多线程

用com调用QCAT处理log时,一开始单线程没有问题,一到多线程程序就崩溃,查到下面这篇文档。

http://irootlee.com/python_pywin32_thread/

因为COM对象属于一个线程,该线程与当前的线程无法正常通信,所以导致在多线程中调用Dispatch函数会报错。

我们需要Windows提供的函数Coinitialize来创建一个套间,使得他们可以正常关联和执行,具体方法就是在多线程中调用COM对象代码前面加上pythoncom.CoInitialize(),最后在COM对象调用结束后加上pythoncom.CoUninitialize()释放资源。

 

四、Python获取终端log

查看QXDM User Guide,python也可以通过COM接口调用QXDM获取终端log。

#初始化
import win32com.client
app = win32com.client.Dispatch("QXDM.QXDMAutoApplication")
qxdm = app.GetAutomationWindow()

#查看QXDM版本
version = qxdm.AppVersion
#加载.dmc配置文件,根据配置文件抓取终端log
qxdm.LoadConfig('XXXXXX.dmc')
#设置终端的调试端口,连接终端
response = qxdm.SetComPort(XX)
#获取当前已经抓到的log的数量
qxdm.GetItemCount()
#存储终端log
qxdm.SaveItemStore('XXXXXX.isf')

#退出QXDM
qxdm.QuitApplication()

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/186749.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • lstm怎么预测长时间序列_时间序列预测代码

    lstm怎么预测长时间序列_时间序列预测代码写在前面LSTM模型的一个常见用途是对长时间序列数据进行学习预测,例如得到了某商品前一年的日销量数据,我们可以用LSTM模型来预测未来一段时间内该商品的销量。但对于不熟悉神经网络或者对没有了解过RNN模型的人来说,想要看懂LSTM模型的原理是非常困难的,但有些时候我们不得不快速上手搭建一个LSTM模型来完成预测任务。下面我将对一个真实的时间序列数据集进行LSTM模型的搭建,不加入很多复杂的功能,快速的完成数据预测功能。问题大概如下:某煤矿有一个监测井,我们每20分钟获…

    2025年10月22日
    2
  • pytorch安装、环境搭建及在pycharm中的设置

    pytorch安装、环境搭建及在pycharm中的设置pytorch安装、环境搭建及在pycharm中设置这两天同学在问我pytorch的安装,因为自己的已经安装好了,但是好像又有点遗忘,所以记录一下。一、安装python直接到官网找到和自己设备匹配的版本下载安装即可。安装过程不会出现太多问题,一般情况下python安装在本机上,故可以直接在终端测试是否安装成功。只需win+R——cmd——输入python,就会输出python的版本信息。…

    2022年8月29日
    3
  • Linux中查看进程状态信息

    Linux中查看进程状态信息Linux中查看进程状态信息一、常用命令总结ps-l列出与本次登录有关的进程信息;ps-aux查询内存中进程信息;ps-aux|grep***查询***进程的详细信息;top查看内存…

    2022年6月21日
    48
  • Java中的LinkedList的方法的应用

    Java中的LinkedList的方法的应用LinkedList其实也就是我们在数据结构中的链表,这种数据结构有这样的特性:分配内存空间不是必须是连续的;插入、删除操作很快,只要修改前后指针就OK了,时间复杂度为O(1);访问比较慢,必须得从第一个元素开始遍历,时间复杂度为O(n);在Java中,LinkedList提供了丰富的方法,可以模拟链式队列,链式堆栈等数据结构,为用户带来了极大的方便,下面看看这些方法的用法:addboole

    2022年6月16日
    29
  • 思科九年pdf_思科中国网站

    思科九年pdf_思科中国网站第1节:思科九年(1)  序  南半球的二月是盛夏。这里白天的阳光炽烈而持久,四处都是耀眼的惨白。电视里的广告说皮肤癌是这个国家的国癌,提醒人们小心这厉害的阳光:要穿长袖的衣服待在阴凉的地方,要戴墨镜涂防晒霜。即便如此,海边的沙滩上还是躺满了裸露大片皮肤晒日光浴的各色人种。他们慵懒地躺着趴着,戴着墨镜看书或者睡觉。他们的孩子在水边嬉戏,他们的狗在四处奔跑。海浪一层层涌来,冲浪者和他们的冲浪

    2022年8月21日
    7
  • ascii码表完整版_ascii码表高清

    ascii码表完整版_ascii码表高清ASCII码表ASCII值控制字符ASCII值控制字符ASCII值控制字符ASCII值控制字符0NUL32(space)64@96、1SOH33!65A97a2STX34”66B98b3ETX35#6

    2022年8月4日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号