小程序大功能对一批报文要处理要处理里面的得分,发现pythonlinecache,特记录如下。#!/usr/bi
小程序大功能
对一批报文要处理要处理里面的得分,发现python linecache ,特记录如下。
#!/usr/bin/env python
# -*- coding: utf-8 -*-
''''提取result结果分值'''
import linecache
import os
import os.path
rootdir = r"./815old/"
for parent, dirnames, filenames in os.walk(rootdir): # 三个参数:分别返回1.父目录 2.所有文件夹名字(不含路径) 3.所有文件名字
for filename in filenames: # 输出文件信息
files = os.path.join(parent, filename) # 输出文件路径信息
count = len(open(files, 'r').readlines()) # 行数
str = linecache.getlines(files) # 所有文件的字符串
filename = str[2] #第三行
if count > 6: # 行数大于5行表示命中
matchRatio = str[8] #第九行
print filename[58:-2], " ", matchRatio[15:], "\r"
else: # 没有命中 matchRatio 赋值0
print filename[58:-2], " ", '0', "\r"
文本格式如下:
results {
fileID: "386e86d2e3991de32a028b7e26e58ffd"
filename: "/opt/vfpgen/video_file/192.168.142.199/video/Avatar.2009.iTALiAN.READNFO.LD.TS.XviD-SiLENT.CD1[S.o.M.].avi"
filetype: 1
vfpQueryResults {
fileID: "09b509f6c625aeb525f6f1c8e09725d6"
filename: "/opt/SmartVision/system/copyrightfpdb//dbfp/09b509f6c625aeb525f6f1c8e09725d6.DB.cdvs"
matchScore: 0.85874754
matchRatio: 0.53333336
dbID: "copyright_library_db"
startframe: 16210
endframe: 97240
}
}
以上这篇python linecache 处理固定格式文本数据的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
python linecache 文本数据