匹配模式并打印下一行
Match the pattern and print next line
我有一个包含特定规则的文本文件。这是它的格式:
:SchoolName (rule_1)
)
:xyz (true)
:abc_efg (
: xxyyzz-x1y1-z1z2-z3z4
)
- 我想匹配 ':abc_efg' 并在匹配后获取行,即
': xxyyzz-x1y1-z1z2-z3z4'
- 每次有一个新文件时,它会查找':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'}
将正则表达式分成多行以便看得更清楚。
我有一个包含特定规则的文本文件。这是它的格式:
:SchoolName (rule_1)
)
:xyz (true)
:abc_efg (
: xxyyzz-x1y1-z1z2-z3z4
)
- 我想匹配 ':abc_efg' 并在匹配后获取行,即 ': xxyyzz-x1y1-z1z2-z3z4'
- 每次有一个新文件时,它会查找':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'}
将正则表达式分成多行以便看得更清楚。