根据您提供的源代码,我修改了一下以实现删除第一行和包含数字8的那行的功能。以下是修改后的代码:
...
你看看这个方法 ssqchina 发表于 2023-7-4 21:25
我是谁
0111111111
3222222222
还不行试试这个
import os
def Modify_String_TXT(Find_String,Replace_String): #创建函数
path = 'F:\\'
files = os.listdir(path) #列举F盘目录下的文件名
for file in files: #遍历路径下的所有文件
file_name,file_extension = os.path.splitext(file) #将文件的文件名和后缀名分开并保存
if(file_extension == '.txt'): #按文件后缀名筛选需要操作的文件
file_path = os.path.join(path, file) #合成文件完整路径名
with open(file_path,'r+',encoding='UTF-8') as f: #此打开方式不需要f.close()
lines = f.readlines() #将每一行的内容存储在列表“lines”中,注意与readline区别
flen = len(lines) #得到列表“lines”的长度
for i in range(flen): #range不含flen,列表最后一个元素的索引值为flen-1
if Find_String in lines: #判断列表“lines”的第i行是否有需要替换的内容
lines = lines.replace(Find_String,Replace_String)
f.seek(0) #指针回到文件内容的起始位置
f.truncate() #清空文件
for line in lines: #遍历更新后的列表“lines”
if line.strip(): #判断每一行是否为空行,如果不为空行,则写入文件
f.write(line)
Modify_String_TXT(' 0','0|0')
Modify_String_TXT(' 3','0|3')
Modify_String_TXT(' 6','1|6')
ssqchina 发表于 2023-7-4 21:37
和刚才一样只剩最后一行
要删除整行中包含特定数字的行,可以在文本替换后添加一个新的循环将符合条件的行删除。以下是修改后的代码:
import os
def Modify_String_TXT(Find_String, Replace_String):
path = 'F:\\'
files = os.listdir(path)
for file in files:
file_name, file_extension = os.path.splitext(file)
if file_extension == '.txt':
file_path = os.path.join(path, file)
with open(file_path, 'r+', encoding='UTF-8') as f:
lines = f.readlines()
flen = len(lines)
for i in range(flen):
if Find_String in lines:
lines = lines.replace(Find_String, Replace_String)
if Replace_String.strip() == '':
del lines
f.seek(0)
f.truncate()
f.writelines(lines)
Modify_String_TXT(' 0', '0|0')
Modify_String_TXT(' 3', '0|3')
Modify_String_TXT(' 6', '1|6')
上述代码中的`if Replace_String.strip() == '':`判断是否需要删除整行。删除整行是通过使用`del`关键字来删除列表中的元素实现的。
请在使用代码之前备份您的文件,以免数据丢失。 @ssqchina 给个最佳答案支持下呗 sfqxx 发表于 2023-7-4 23:26
@ssqchina 给个最佳答案支持下呗
我开了个悬赏贴,那个运行符合我的要求,其余试了都不符合我的要求,不过非常感谢你!!! 123 123
页:
1
[2]