我有一个看起来像这样的文本文件:blah blahfoo1 bar1foo1 bar2foo1 bar3foo2 bar4foo2 bar5blah blah现在我要'foo bar'在'foo1 bar3'和之间插入'foo2 bar4'。这是我的方法:import shutiltxt = '1.txt'tmptxt = '1.txt.tmp'with open(tmptxt, 'w') as outfile: with open(txt, 'r') as infile: flag = 0 for line in infile: if not line.startswith('foo1') and flag == 0: outfile.write(line) continue if line.startswith('foo1') and flag == 0: flag = 1 outfile.write(line) continue if line.startswith('foo1') and flag == 1: outfile.write(line) continue if not line.startswith('foo1') and flag == 1: outfile.write('foo bar\n') outfile.write(line) flag = 2 continue if not line.startswith('foo1') and flag == 2: outfile.write(line) continueshutil.move(tmptxt, txt)这对我有用,但是看起来很丑。
3 回答
data:image/s3,"s3://crabby-images/e7ad6/e7ad68e96b2c440661c711750101f492a809424c" alt="?"
拉莫斯之舞
TA贡献1820条经验 获得超10个赞
改编Alex Martelli的示例:
import fileinput
for line in fileinput.input('1.txt', inplace=1):
print line,
if line.startswith('foo1 bar3'):
print 'foo bar'
data:image/s3,"s3://crabby-images/3f1e7/3f1e7d1dd6080d1a634e344279d1f34a58f5ed9b" alt="?"
开心每一天1111
TA贡献1836条经验 获得超13个赞
回想一下,迭代器是一流的对象。它可以用于多个for语句。
这是一种无需大量复杂外观的if语句和标志即可解决此问题的方法。
with open(tmptxt, 'w') as outfile:
with open(txt, 'r') as infile:
rowIter= iter(infile)
for row in rowIter:
if row.startswith('foo2'): # Start of next section
break
print row.rstrip(), repr(row)
print "foo bar"
print row
for row in rowIter:
print row.rstrip()
添加回答
举报
0/150
提交
取消