根据您的描述,您想对文本文件进行替换和删除操作。以下是修改后的代码,可以满足您的需求:pythonimport osdef 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”中 lines_to_write = [] delete_line = False for line in lines: if Find_String in line: # 判断列表“lines”的每一行是否包含需要替换的内容 line = line.replace(Find_String, Replace_String) # 替换字符串 if line.strip().startswith('8'): # 判断是否为以8开头的行 delete_line = True else: lines_to_write.append(line) # 将不需要删除的行添加到新的列表中 if delete_line: lines_to_write = lines_to_write[1:] # 删除第一行 f.seek(0) # 指针回到文件内容的起始位置 f.truncate() # 清空文件 f.writelines(lines_to_write) # 将更新后的列表“lines_to_write”重新写入文件Modify_String_TXT(' 0', '0|0')Modify_String_TXT(' 3', '0|3')Modify_String_TXT(' 6', '1|6')
在修改后的代码中,我添加了一个变量delete_line来判断是否需要删除含有以8开头的行。如果需要删除,则将待写入文件的列表lines_to_write从第2行开始操作,即删除了原文本的第一行。否则,保留所有行。
请注意,这段代码将会遍历指定路径下的所有.txt文件,并对每个文件进行替换和删除操作。如果您只想处理特定的文件,请根据您的需求进行相应的修改。同样,在运行代码之前,请确保备份您的文件,以免意外数据损失。 |