Python自动查重:原理、方法与实践

Python自动查重:原理、方法与实践

什么是自动查重?

自动查重是指使用计算机程序来比较两个或多个文件的内容,判断它们之间是否存在相似或相同的部分,从而检测出抄袭或重复的情况。自动查重可以用于学术论文、代码、文本等各种类型的文件,帮助提高原创性和质量。

为什么要使用Python进行自动查重?

Python是一种广泛使用的编程语言,具有简洁、易读、灵活和强大的特点。Python中有许多现成的库和工具,可以方便地实现自动查重的功能。其中,difflib库就是一个专门用于比较文件和字符串差异的库,它提供了多种方法和API,可以根据不同的需求和场景进行自动查重。

如何使用Python中的difflib库进行自动查重?

pip install cdifflib

difflib库中最常用的两个类是SequenceMatcherDiffer,它们都可以用来比较两个序列(如字符串、列表、元组等)之间的差异,并生成相应的结果。

SequenceMatcher

SequenceMatcher类可以用来计算两个序列之间的相似度,以及找出它们最长的匹配子序列。它有以下几个主要的方法:

  • __init__(a, b, isjunk=None):创建一个SequenceMatcher对象,参数ab是要比较的两个序列,参数isjunk是一个可选的函数,用于指定哪些元素应该被忽略。
  • ratio():返回两个序列之间的相似度,范围在0到1之间,越接近1表示越相似。
  • quick_ratio():返回两个序列之间的快速估计相似度,比ratio()方法更快但可能不太准确。
  • real_quick_ratio():返回两个序列之间的非常快速估计相似度,比quick_ratio()方法更快但可能更不准确。
  • get_matching_blocks():返回一个列表,包含了两个序列中最长匹配子序列的信息,每个元素是一个元组(i, j, n),表示第一个序列中从索引i开始长度为n的子序列与第二个序列中从索引j开始长度为n的子序列完全匹配。
  • get_opcodes():返回一个列表,包含了将第一个序列转换为第二个序列所需的操作,每个元素是一个元组(tag, i1, i2, j1, j2),表示对第一个序列中从索引i1到索引i2(不包括)的子序列执行操作tag后,它将与第二个序列中从索引j1到索引j2(不包括)的子序列相等。操作有以下几种:
    • 'equal': 表示两个子序列相等,无需修改。
    • 'replace': 表示需要将第一个子序列替换为第二个子序列。
    • 'delete': 表示需要删除第一个子序列。
    • 'insert': 表示需要在第一个子序列后插入第二个子序列。
    • 'noop': 表示无操作。
Differ

Differ类可以用来生成两个序列之间的差异报告,以便于人类阅读和理解。它有以下几个主要的方法:

  • __init__(linejunk=None, charjunk=None):创建一个Differ对象,参数linejunkcharjunk是两个可选的函数,用于指定哪些行或字符应该被忽略。
  • compare(a, b):返回一个生成器,逐行比较两个序列ab,并生成差异报告。每一行的开头有一个标记,表示该行的状态,有以下几种:
    • ' ': 表示该行在两个序列中都存在,无差异。
    • '-': 表示该行只在第一个序列中存在,被删除。
    • '+': 表示该行只在第二个序列中存在,被添加。
    • '?': 表示该行在两个序列中有不同的字符,需要进一步比较。

一个简单的例子

为了演示如何使用difflib库进行自动查重,我们可以用它来比较两篇文章的内容,并输出相似度和差异报告。假设我们有以下两篇文章:

文章A:

Python是一种高级编程语言,它的设计哲学是“优雅”、“明确”、“简单”。Python拥有动态类型系统和垃圾回收功能,能够自动管理内存使用,并且支持多种编程范式,包括面向对象、命令式、函数式和过程式编程。Python的语法简洁而清晰,使用缩进来表示代码块,从而减少了代码的冗余。Python解释器本身几乎可以在所有的操作系统中运行。Python的标准库提供了丰富的功能,包括图形界面、数据库、网络、多线程、正则表达式等。Python还有许多第三方库和框架,可以用于科学计算、数据分析、机器学习、Web开发等领域。Python是一种通用的编程语言,适用于各种应用场景。

文章B:

Python是一门通用的高级编程语言。它具有简单明确的语法,使用缩进来组织代码结构。Python支持多种编程范式,如面向对象、函数式和过程式编程。Python具有动态类型系统和自动内存管理功能,可以适应不同的需求和环境。Python可以在多种操作系统中运行,并且拥有庞大的标准库和第三方库,涵盖了图形界面、数据库、网络、多线程、正则表达式等各种功能。Python还可以用于科学计算、数据分析、机器学习、Web开发等领域。Python是一门优雅而强大的编程语言,适合各种应用场景。

我们可以将这两篇文章保存为两个文本文件,分别命名为article_a.txtarticle_b.txt,然后使用以下代码来进行自动查重:

# 导入difflib库
import difflib# 打开并读取两个文本文件
with open('article_a.txt', 'r', encoding='utf-8') as f:a = f.read()
with open('article_b.txt', 'r', encoding='utf-8') as f:b = f.read()# 创建一个SequenceMatcher对象
sm = difflib.SequenceMatcher(None, a, b)# 计算并打印两篇文章的相似度
similarity = sm.ratio()
print(f'相似度:{similarity:.2f}')# 创建一个Differ对象
d = difflib.Differ()# 比较并生成差异报告
diff = d.compare(a.splitlines(), b.splitlines())# 打印差异报告
print('差异报告:') 
for line in diff: print(line)

运行结果如下图:

总结

本教程介绍了如何使用Python中的difflib库进行自动查重,主要介绍了SequenceMatcher和Differ两个类的用法和API,以及一个简单的例子。通过使用difflib库,我们可以方便地比较两个文件或字符串之间的相似度和差异,并生成可读的结果。这对于检测抄袭或重复的情况,提高原创性和质量,有很大的帮助。希望本教程能够对你有所启发和帮助。😊

如果你对Python感兴趣,想要学习python,这里给大家分享一份Python全套学习资料,都是我自己学习时整理的,希望可以帮到你,一起加油!

😝有需要的小伙伴,可以点击下方链接免费领取或者V扫描下方二维码免费领取🆓
Python全套学习资料

在这里插入图片描述

1️⃣零基础入门

① 学习路线

对于从来没有接触过Python的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

② 路线对应学习视频

还有很多适合0基础入门的学习视频,有了这些视频,轻轻松松上手Python~
在这里插入图片描述

③练习题

每节视频课后,都有对应的练习题哦,可以检验学习成果哈哈!
在这里插入图片描述

2️⃣国内外Python书籍、文档

① 文档和书籍资料

在这里插入图片描述

3️⃣Python工具包+项目源码合集

①Python工具包

学习Python常用的开发软件都在这里了!每个都有详细的安装教程,保证你可以安装成功哦!
在这里插入图片描述

②Python实战案例

光学理论是没用的,要学会跟着一起敲代码,动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。100+实战案例源码等你来拿!
在这里插入图片描述

③Python小游戏源码

如果觉得上面的实战案例有点枯燥,可以试试自己用Python编写小游戏,让你的学习过程中增添一点趣味!
在这里插入图片描述

4️⃣Python面试题

我们学会了Python之后,有了技能就可以出去找工作啦!下面这些面试题是都来自阿里、腾讯、字节等一线互联网大厂,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
在这里插入图片描述
在这里插入图片描述

5️⃣Python兼职渠道

而且学会Python以后,还可以在各大兼职平台接单赚钱,各种兼职渠道+兼职注意事项+如何和客户沟通,我都整理成文档了。
在这里插入图片描述

上述所有资料 ⚡️ ,朋友们如果有需要的,可以扫描下方👇👇👇二维码免费领取🆓
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/236714.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最佳软件配置管理工具(16款SCM工具)

配置管理(CM)是一种系统工程方法,用于在产品的整个生命周期内建立和维持产品的性能,功能和物理属性与其设计,要求和操作信息的一致性。 它们为您的组织带来了成本效益和更好的时间管理。 当今市场充斥着各种配置管理工…

jmeter做接口自动化测试,你可能只是个新手!

jmeter 这个工具既可以做接口的功能测试,也可以做自动化测试,还可以做性能测试,其主要用途就是用于性能测试。但是,有些公司和个人,就想用 jmeter 来做接口自动化测试。你有没有想过呢?下面我就给大家讲讲&…

简化版Transformer :Simplifying Transformer Block论文详解

在这篇文章中我将深入探讨来自苏黎世联邦理工学院计算机科学系的Bobby He和Thomas Hofmann在他们的论文“Simplifying Transformer Blocks”中介绍的Transformer技术的进化步骤。这是自Transformer 开始以来,我看到的最好的改进。 大型语言模型(llm)可以通过各种扩展…

单片机学习12——电容

电容的作用: 1)降压作用: 容抗: Xc 1/2fc 串联分压原理。2100Ω的容量,50Hz的频率,可以得到1.5uF。断电之后,需要串联一个1MΩ的电阻放电。 那是不是可以使用2100欧姆的电阻来代替电容呢&am…

GAN:WGAN前作

WGAN前作:有原则的方法来训练GANs 论文:https://arxiv.org/abs/1701.04862 发表:ICLR 2017 本文是wgan三部曲的第一部。文中并没有引入新的算法,而是标是朝着完全理解生成对抗网络的训练动态过程迈进理论性的一步。 文中基本是…

这篇文章绝了!!现在都在“卷”统计学方法了吗?

欢迎参加郑老师2023年孟德尔随机化课程 发表文章后退款!孟德尔随机化方法快速撰写SCI论文” 这些年,公共数据库的文章越发越多,也越来越难发。 现在获取公共数据库的门槛也越来越低,现在想发好文章,除了idea要好&…

办公软件PDF转换工具 - Bruce的PDF工具pdftool

Bruce的PDF工具 - 办公软件PDF转换工具 - pdftool,支持: 1、图片转PDF,支持图片自动压缩,可预览图片 2、合并PDF,支持多个PDF合并成一个PDF 3、PDF转图片,PDF的每页转成一张图片 4、OFD转PDF,O…

web:catcat-new(文件包含漏洞、flask_session伪造)

前提知识 /etc/passwd 该文件储存了该Linux系统中所有用户的一些基本信息,只有root权限才可以修改。其具体格式为 用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录Shell(以冒号作为分隔符) /proc/self proc是一个伪文件系统…

数据结构-03-栈

1-栈的结构和特点 先进后出,后进先出 是栈的特点; 从图中,我们看到A入栈先放入底部,然后依次B和C;出栈的顺序依次是C-B-A;这种结构只能在一端操作。所以当某个数据集合只涉及在一端插入和删除数据&#xf…

数据治理的具体应用

数据治理架构 图 13 描述的是公安数据治理框架,平台架构主要包括数据存储、数据计算、数据管理、数据应用这 4 个部分。 (1) 数据存储: 基于分布式的大数据存储平台,具有很强的存储能力和扩张能力; (2) 数据计算: …

小语种翻译重要吗,如何做好小语种翻译

随着全球化不断推进,不同语言之间的交流日益密切,小语种翻译的重要性日益凸显。小语种翻译不仅有助于人们更好地相互理解与沟通,更能促进不同文化之间的交流与融合,做好小语种翻译至关重要。那么,如何做好小语种翻译呢…

mysql mybatis分页查询 大数据量 非常慢

查阅了很多博客和资料,这篇文章以思路为准,详细代码不细说,都是非常简单的方法,一看就明白。具体实现稍微百度一下就能出来。仅供参考。 如题:单表数据已经达到4千万条数据,通过mybatis的分页查询效率非常低…