在python中从文本文件中过滤和提取字段

2024-10-05 10:11:46 发布

您现在位置:Python中文网/ 问答频道 /正文

我有以下格式的文本文件。在

03/12 20:23:26.11: 04:23:26 L9 <Mx  Acc  Magnum All            XDV:00111A0000000117 00D3001200870172 01FF6000F01CFE81 3D26000000000300
03/12 20:23:26.11: 04:23:26 L9 <Mx  Acc  MID 0x1500 Len 26   XDV:00111A0000000117 00D3001200870172 01FF6000F01CFE81 3D26000000000300
03/12 20:23:26.11: 04:23:26 L8 <Mx  JK31 (Mx)                  JSP:17.37.6.99: Size = 166, Data: 00345C4101003031 E463EF0113108701 5A01FF6008F01CFE 81AB170000000003 EF01131087015A01 FF6008F01CFE81AB 170000000003EF01 131087015B01FF60 00F01CFE81701B00 00000003EF011310 87015B01FF6000F0 1CFE81701B000000 0003EF0113108701 5C01FF2000F01CFE 81CB240000000003 EF01131087015C01 57CC00F01CFE81CB 240000000003EF01 131087015D01FF20 00F01CFE815B2900 00000003EF011310 87015D01FF2000F0 1CFE815B29000000 0003EF0113108701 5E01FF6000F01CFE 819D280000000003 EF01131087015E01 FF6000F01CFE819D 0003
03/15 20:23:26.11: 04:23:26 L8 <Kx  JK49 (Kx)                  JSP:15.33.2.93: Size = 163, Data: 00647741000030EF 01131087015A01FF 6008F01CFE81AB17 0000000003EF0113 1087015A01FF6008 F01CFE81AB170000 000003EF01131087 015B01FF6000F01C FE81701B00000000 03EF01131087015B 01FF6000F01CFE81 701B0000000003EF 01131087015C01FF 2000F01CFE81CB24 0000000003EF0113 1087015C01FF2000 F01CFE81CB240000 000003EF01131087 015D01FF2000F01C FE815B2900000000 03EF01131087015D 01FF2000F01CFE81 5B290000000003EF 01131087015E01FF 6000F01CFE819D28 0000000003EF0113 1087015E01FF6000 F01CFE819D280000 A6220000000003
03/15 20:23:26.11: 04:23:26 L8 <Kx  JK21 (Kx)                  JSP:10.22.1.53:Size = 163, Data: 009D1141000030EF 01131087015A01FF 6008F01CFE81AB17 0000000003EF0113 1087015A01FF6008 F01CFE81AB170000 000003EF01131087 015B01FF6000F01C FE81701B00000000 03EF01131087015B 01FF6000F01CFE81 701B0000000003EF 01131087015C01FF 2000F01CFE81CB24 0000000003EF0113 1087015C01FF2000 F01CFE81CB240000 000003EF01131087 015D01FF2000F01C FE815B2900000000 03EF01131087015D 01FF2000F01CFE81 5B290000000003EF 01131087015E01FF 6000F01CFE819D28 0000000003EF0113 1087015E01FF6000 F01CFE819D280000 A6220000000003

我想逐行提取应用过滤器的文件它。为了示例我要提取其中包含L8 <Mx JK31 (Mx)的所有行,提取时间(04:23:26)和大小(166),并绘制一个随时间变化的大小图。我想用python来做这个。在

^{pr2}$

我能够提取所有带有预期文本的行。(if match in line:),如何在python中提取时间字段和大小字段?在


Tags: datasize时间accmxxdvjspkx
3条回答

在不使用其他模块的情况下扩展您的方法,以下解决方案可以工作:

match = "L8 <Mx  JK31 (Mx)"

with open("test.txt") as fin:
    print(' : {}', fin.name)
    for line in fin:
        if match in line:
            print(line)
            sizeStart = line.find("Size = ")
            sizeEnd = line[sizeStart:].find(',')
            size =  line[sizeStart+len("Size = "):sizeStart+sizeEnd]


            time1_start = line.find(" ")
            time1_end = line[time1_start+1:].find(" ")
            time1 = line[time1_start+1:time1_start+time1_end]

            print size, time1

同样,你可以得到time2。我尽量减少了对re模块的依赖,因为我必须习惯于晦涩的语法。更具可读性的东西值得商榷。在

您还可以使用正则表达式来进行更精确的匹配:

m = re.search(r':\s(\d\d:\d\d:\d\d) L8 \<Mx\s+JK31 \(Mx\).*Size = (\d+),', line)
if m:
    # found match
    print('Time: {}'.format(m.group(1)))
    print('Size: {}'.format(m.group(2)))
# else:
    # pattern was not found: handle it or error

提取时间和大小如下:

# !/usr/bin/env python
# -*- coding: utf-8 -*-

match = ("L8 <Mx JK31 (Mx)")
with open("test.txt") as fin:
    print(' : {}', fin.name)
    for line in fin:
        if match in line:
            line = line.strip.split()
            time = line[2]
            size = line[9].strip(",")

相关问题 更多 >

    热门问题