首页 > 解决方案 > 如何根据文件编号分隔不同的文本文件

问题描述

我在一个文件夹中有 20 个文本文件。文件名表示为

a 1.txt,a 2.txt,a 3.txt...

有些文件有不同的操作,有些则不同

我已将文件编号传递给list lst_num=[1,6,15,16]这样的所有文件都需要写入一个文件,不在列表中的文件应该写入另一个文件

for file in fnames:
    nume=os.path.splitext(file)[0].split()[1]
    lst_num=[1,6,15,16]
    fp = open(file, 'r').read()
    for i in lst_num:
        if file=="a "+str(i)+".html":
            print(file)
        else: 
            print('--'+file)

列表中的所有文件都传递给一个文本文件而不是列表中的另一个文件

标签: pythonpython-3.xtext-processing

解决方案


您当前的代码正在与html文件进行比较,但您的文件扩展名实际上是txt
您的双 for 循环最终将多次打印相同的文件名

您实际上不需要遍历文件和lst_num.
只需创建lst_num用于写入一个文件的文件名,然后通过获取所有文件和lst_num文件之间的差异来获取要写入另一个文件的文件名

fnames = ['a 1.txt', 'a 2.txt'....]
lst_num=[1,6,15,16]

#All files in lst_num
in_list_files = ['a {}.txt'.format(item) for item in lst_num]

#All files outside lst_num
not_in_list_files = list(set(fnames) - set(in_list_files))

print(in_list_files)
print(not_in_list_files)

输出将是

['a 1.txt', 'a 6.txt', 'a 15.txt', 'a 16.txt']
['a 2.txt', 'a 3.txt', 'a 4.txt', ....]

推荐阅读