有一个文件夹有多个test.log文件
文件内容有多行,提示信息可能不一样,我只需要有下面license failure的这部分:
2021-01-01 07:58:29 Connect from 192.168.1.1 (username/hostname)licensekey1-ABC123456
2021-01-01 07:58:29 Key for 192.168.1.1 (username/hostname)change to licensekey2
2021-01-01 07:58:29 no valid license for floating license key licensekey2, license failure
如何用python在log中抓到“license failure”的关键字,并提取 时间戳,IP地址,username, hostname, license key 1, license key2并写入CSV文件相应的字段里,谢谢🙏
![](https://profile-avatar.csdnimg.cn/default.jpg!4)
用python提取log中的失败信息的相关参数
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
6条回答 默认 最新
- xdspower 2022-06-30 08:55关注
你的日志中能保证稳定的结构吗?
就是在license failure
的前两行中肯定是类似Connect from 192.168.1.1 (username/hostname)licensekey1-ABC123456
和Key for 192.168.1.1 (username/hostname)change to licensekey2
如果是,则依次移动日志的行指针,先查找
license failure
标志,再在其前面2行中提取你需要的数据即可。
大致为(此外你的licensekey1
和licensekey2
特征是什么还可能影响下面的正/规则式的具体实现。):import os import re path = r"E:/xxx" #读取文件的目录路径 for root, dirs, files in os.walk(path): for fn in files: if fn.endswith(".log"): # 依次读取文件 fh = os.path.join(root,fn) print("文件:",fh) with open(fh, 'r', encoding='utf-8') as fileObj: r1=“” r2=“” r3=“” for aline in fileObj.readline() if r1==“”: r1=aline continue if r2==“”: r2=aline continue r3=aline matchObj = re.search( r"license failure", r3) if matchObj :# 在第3行搜索到特征值,在其上2行中检索信息 result1 = re.findall(r'^(\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2})\s*Connect\s+from\s+([ABCDEF\d\.:]+)\s*\((.+)/(.+)\)\s*key\s+([a-z]{4}-[a-z]{4}-[a-z]{4}-[a-z]{4}\s+-\s+[A-Z][A-Z]\d{14})$',r1) #这里提取时间戳、来源IP,username、hostname 、licensekey1 result2 =re.findall(r'^\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2}\s+Key\s+for\s+[ABCDEF\d\.:]+\s*\(.+/.+\)\s*change to\s+([a-z]{4}-[a-z]{4}-[a-z]{4}-[a-z]{4}).*$',,r2) # 这里提取linsekey2 print("T:{}\nIP:{}\nusername:{}\nhostname:{}\nlicensekey1:{}\nlicensekey2:{}".format(result1[0][0],result1[0][1],result1[0][2],result1[0][3],result1[0][4],result2[0][0])) # 根据要求输出提取到的信息,这里没有精确处理,可能还需要调整 r1="" r2="" else: r1=r2 r2=r3
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 在若依框架下实现人脸识别
- ¥15 网络科学导论,网络控制
- ¥100 安卓tv程序连接SQLSERVER2008问题
- ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
- ¥15 metadata提取的PDF元数据,如何转换为一个Excel
- ¥15 关于arduino编程toCharArray()函数的使用
- ¥100 vc++混合CEF采用CLR方式编译报错
- ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
- ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
- ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同