匹配模式并打印下一行

Match the pattern and print next line

我有一个包含特定规则的文本文件。这是它的格式:

:SchoolName (rule_1)
)
:xyz (true)
:abc_efg (
    : xxyyzz-x1y1-z1z2-z3z4
)
  1. 我想匹配 ':abc_efg' 并在匹配后获取行,即 ': xxyyzz-x1y1-z1z2-z3z4'
  2. 每次有一个新文件时,它会查找':abc_efg'并在匹配后得到相应的行

到目前为止我已经试过了

with open('G:\CM\Python Exercises\Project_F\abc.txt') as f:
    text = f.read()
    list1=text.strip('\n\t').split(':')
    print list1
    for line in list1:
        if ':abc_efg' in list1:
            print line
            print '\n'.join(list1[i+1])

打印列表 1 显示

[':abc_efg (\n\t\t\t', ': xxyyzz-x1y1-z1z2-z3z4 \n\t\t)\n\t\t']

使用 f.readline() 逐行读取文件。

匹配时很容易得到下一行。

with open('abc.txt') as f:
    a = ' '
    while(a):
        a = f.readline()
        l = a.find(':abc_efg') #Gives a non-negative value when there is a match
        if ( l >= 0 ):
            print f.readline()

使用以下正则表达式,首先它是高效的,其次,如果用于繁重的解析,str 方法将失去控制。

import re
pat = re.compile(r":(?P<x>.+?)\s\(\s+:\s(?P<y>.+?)\s\)")
with open(somefile) as fr:
    match = pat.search(fr.read())
    print(match.groupdict())


Out[111]: {'x': 'abc_efg', 'y': 'xxyyzz-x1y1-z1z2-z3z4'}

将正则表达式分成多行以便看得更清楚。