在本文中,将介绍使用 Python 从文本文件中删除行的几种方法。由于 Python 没有提供删除文件中特定行的直接方法,因此有必要找到我们自己的方法。
文中示例使用的文本文件 “1.txt” 内容如下:
穿针引线
无忧无虑
无地自容
学习
三位一体
原来如此
落叶归根
相见恨晚
惊天动地
滔滔不绝
相濡以沫
方法1:按照行号删除行
可以使用 with 语句来安全地打开文件,使用 readlines() 方法来读取内容。
使用另一个 with 语句在写入模式下再次打开文件。使用 for 循环遍历刚才读取的内容,使用变量来跟踪当前行号,当到达要删除的行时,跳过该行的写入。
def remove_line(fileName,lineToSkip):
with open(fileName,'r', encoding='utf-8') as read_file:
lines = read_file.readlines()
currentLine = 1
with open(fileName,'w', encoding='utf-8') as write_file:
for line in lines:
if currentLine == lineToSkip:
pass
else:
write_file.write(line)
currentLine += 1
remove_line("1.txt",7)
方法2:通过匹配内容删除行
如何删除与给定字符串匹配的行?
首先使用 readlines() 方法来读取内容。
使用另一个 with 语句在写入模式下再次打开文件,使用 for 循环遍历刚才读取的内容并写入文件。为了能够匹配内容,还需要使用 strip() 函数删除每行末尾的换行符,再进行比较。找到匹配的内容后,跳过该行的写入。
with open("1.txt", 'r', encoding='utf-8') as file:
lines = file.readlines()
content = "原来如此"
with open("1.txt", 'w', encoding='utf-8') as file:
for line in lines:
if line.strip("\n") != content:
file.write(line)
方法3:删除包含特定字符串的行
在 Python 中,find() 方法可用于在字符串中搜索子字符串。如果字符串包含子字符串,则该函数返回表示其位置的索引。否则,返回 -1。
同前面的例子一样,先读取文件内容,再写入文件。在写入文件时,使用 find() 检测是否包含正在寻找的字符串,如果发现给定的字符串,跳过该行的写入。
with open("1.txt",'r', encoding='utf-8') as file:
lines = file.readlines()
with open("1.txt",'w', encoding='utf-8') as file:
for line in lines:
if line.find("无忧") != -1:
pass
else:
file.write(line)
方法4:删除文件中最短的行
需要删除文档中最短的一行,可以通过使用 len() 方法来查找每行的长度,使用循环找到长度最短的一行,记录行号。在写入文件时,跳过该行的写入。
with open("1.txt",'r', encoding='utf-8') as read_file:
lines = read_file.readlines()
shortest = 1000
lineToDelete = ""
for line in lines:
if len(line) < shortest:
shortest = len(line)
lineToDelete = line
with open("1.txt",'w', encoding='utf-8') as write_file:
for line in lines:
if line == lineToDelete:
pass
else:
write_file.write(line)
文章创作不易,如果您喜欢这篇文章,请关注、点赞并分享给朋友。如有意见和建议,请在评论中反馈。