Python会在读取时截断行

Ryan White 12 python file-io

我有一个应用程序从文件中读取行,并在读取每行时运行其魔法.一旦读取并正确处理了该行,我想从文件中删除该行.已保留已删除行的备份.我想做点什么

file = open('myfile.txt', 'rw+')
for line in file:
   processLine(line)
   file.truncate(line)

这似乎是一个简单的问题,但我想做的不错,而不是一大堆复杂的seek()和tell()调用.

也许我真正想做的就是从文件中删除一个特定的行.

在花了很长时间来解决这个问题后,我认为每个人都可能是对的,这不是一个好办法.它似乎是如此优雅的解决方案.我正在寻找的东西类似于FIFO,它只会让我从文件中弹出行.

jfs.. 18

完成后删除所有行:

with open('myfile.txt', 'r+') as file:
    for line in file:
        processLine(line)
    file.truncate(0)

独立删除每一行:

lines = open('myfile.txt').readlines()

for line in lines[::-1]: # process lines in reverse order
    processLine(line)
    del lines[-1]  # remove the [last] line

open('myfile.txt', 'w').writelines(lines)

您只能留下导致异常的那些行:

import fileinput

for line in fileinput.input(['myfile.txt'], inplace=1):
    try: processLine(line)
    except Exception:
         sys.stdout.write(line) # it prints to 'myfile.txt'

一般来说,正如其他人已经说过你想要做的事情一个坏主意.


nosklo.. 9

你不能.在当前文件系统上实际的文本文件实现是不可能的.

文本文件是顺序的,因为文本文件中的行可以是任意长度.删除特定行意味着从该点重写整个文件.

假设您有一个包含以下3行的文件;

'line1\nline2reallybig\nline3\nlast line'

要删除第二行,您必须移动磁盘中的第三行和第四行的位置.唯一的方法是将第三行和第四行存储在某处,截断第二行的文件,然后重写缺失的行.

如果你知道文本文件中每一行的大小,你可以在任何位置使用截断文件,.truncate(line_size * line_number)但即使这样你也必须在行之后重写所有内容.


sykora.. 6

你最好保留一个索引到文件中,这样你就可以从最后停止的地方开始,而不会破坏文件的一部分.像这样的东西会起作用:

try :
    for index, line in enumerate(file) :
        processLine(line)
except :
    # Failed, start from this line number next time.
    print(index)
    raise