首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >根据内容对同一目录中的文件进行分组

根据内容对同一目录中的文件进行分组
EN

Stack Overflow用户
提问于 2018-05-29 06:05:46
回答 1查看 136关注 0票数 1

我有一个关于对具有相同内容但文件名不同的文件进行分组的问题。我查看了filecmp.cmp(),但一次只能比较两个文件。

我们的想法是把这样的东西变成:

代码语言:javascript
复制
file1: [a,b,c,d,e,f,g,h,i]
file2: [a,b,c,d,e,f,g,h,i]
file3: [a,b,c,d,e,f,g,h,i]
file4: [a,b,c,d,e,f,g,h]
file5: [a,b,c,d,e,f,g,h]
file6: [a,b,c,d,e]

进入:

代码语言:javascript
复制
file(1,2,3): [a,b,c,d,e,f,g,h,i]
file(4,5): [a,b,c,d,e,f,g,h]
file(6): [a,b,c,d,e]

我想我有大约1800个.txt文件,但只有大约20个独特的文件。我想创建一个显示分组的列表、字典或数据框。

任何帮助都是非常感谢的。谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-29 06:32:05

一种经典的方法是使用字典。首先完成目录中所有文件名的列表,并将其存储到名为file_names的列表中。然后:

代码语言:javascript
复制
filedict={}
for name in file_names:
    file=open(name,"r")
    filecontents=file.read()
    if filecontents in filedict:
        filedict[filecontents].append(name)
    else:
        filedict[filecontents]=[]
        filedict[filecontents].append(name)

此字典的每个值都将是具有相同文本内容的文件列表。字典的键将是文件的字符串。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50573900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档