python 实现两个文本文件内容去重

嗨喽,大家好呀~这里是爱看美女的茜茜呐

👇 👇 👇 更多精彩机密、教程,尽在下方,赶紧点击了解吧~

python源码、视频教程、插件安装教程、资料我都准备好了,直接在文末名片自取就可


实现两个文本内容去重,输出两个文本不重复的结果

两个测试文本内容如下

cpp 复制代码
1.txt中内容为 1 2 3 4 5 6 7 8
2.txt中内容为 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 

分别读取两个文本的内容

读取1.txt的内容,具体实现如下:

cpp 复制代码
str1 = []
file_1 = open("1.txt","r",encoding="utf-8")
for line in file_1.readlines():
    str1.append(line.replace("\n",""))

读取2.txt的内容,具体实现如下:

cpp 复制代码
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:261823976
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
str2 = []
file_2 = open("2.txt", "r", encoding="utf-8")
for line in file_2.readlines():
    str2.append(line.replace("\n", ""))   

取出重复的内容

创建一个空列表,将两个文件中重复的内容取出来,具体实现如下:

cpp 复制代码
str_dump = []
for line in str1:
    if line in str2:
        str_dump.append(line)    #将两个文件重复的内容取出来

去掉重复内容

将两个文本的内容合并,去除重复的内容

cpp 复制代码
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:261823976
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
str_all = set(str1 + str2)      #将两个文件放到集合里,过滤掉重复内容
for i in str_dump:              
    if i in str_all:
        str_all.remove(i)       #去掉重复的文件

完整代码如下

cpp 复制代码
def file_qc():
    str1 = []
    file_1 = open("1.txt","r",encoding="utf-8")
    for line in file_1.readlines():
        str1.append(line.replace("\n",""))

    str2 = []
    file_2 = open("2.txt", "r", encoding="utf-8")
    for line in file_2.readlines():
        str2.append(line.replace("\n", ""))

    str_dump = []
    for line in str1:
        if line in str2:
            str_dump.append(line)    #将两个文件重复的内容取出来

    str_all = set(str1 + str2)      #将两个文件放到集合里,过滤掉重复内容

    for i in str_dump:              
        if i in str_all:
            str_all.remove(i)		#去掉重复的文件

    for str in str_all:             #去重后的结果写入文件
        print(str)
        with open("qc_V.txt","a+",encoding="utf-8") as f:
            f.write(str + "\n")

if __name__=="__main__":
    file_qc()

输出结果为

尾语

感谢你观看我的文章呐~本次航班到这里就结束啦 🛬

希望本篇文章有对你带来帮助 🎉,有学习到一点知识~

躲起来的星星🍥也在努力发光,你也要努力加油(让我们一起努力叭)。

最后,宣传一下呀~👇👇👇更多源码、资料、素材、解答、交流皆点击下方名片获取呀👇👇

相关推荐
花鱼白羊7 分钟前
TCP Vegas拥塞控制算法——baseRtt 和 minRtt的区别
服务器·网络协议·tcp/ip
云川之下9 分钟前
【linux】 unshare -user -r /bin/bash命令详解
linux·bash·unshare
源码哥_博纳软云17 分钟前
JAVA同城服务场馆门店预约系统支持H5小程序APP源码
java·开发语言·微信小程序·小程序·微信公众平台
学会沉淀。25 分钟前
Docker学习
java·开发语言·学习
如若12326 分钟前
对文件内的文件名生成目录,方便查阅
java·前端·python
热心市民运维小孙26 分钟前
Ubuntu重命名默认账户
linux·ubuntu·excel
PyAIGCMaster28 分钟前
文本模式下成功。ubuntu P104成功。
服务器·数据库·ubuntu
西猫雷婶1 小时前
python学opencv|读取图像(二十一)使用cv2.circle()绘制圆形进阶
开发语言·python·opencv
kiiila1 小时前
【Qt】对象树(生命周期管理)和字符集(cout打印乱码问题)
开发语言·qt
小_太_阳1 小时前
Scala_【2】变量和数据类型
开发语言·后端·scala·intellij-idea