初步实现检测文件查重的检测

本文介绍了如何利用SHA-256算法计算文件的哈希值,以检查两个文件是否内容相同,从而用于学校上机考试中的抄袭检测。函数`calculate_file_hash`负责生成文件的哈希值,`check_duplicate_files`则用于比较两个文件的哈希,判断它们是否为重复内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

适用于学校上机考试,查看是否有抄袭的现象。使用SHA-256算法计算文件的哈希值,并比较两个文件是否相同。

import hashlib

def calculate_file_hash(file_path, block_size=65536):
    sha256 = hashlib.sha256()
    with open(file_path, 'rb') as file:
        for block in iter(lambda: file.read(block_size), b''):
            sha256.update(block)
    return sha256.hexdigest()

def check_duplicate_files(file_path1, file_path2):
    hash1 = calculate_file_hash(file_path1)
    hash2 = calculate_file_hash(file_path2)

    if hash1 == hash2:
        print(f"The files {file_path1} and {file_path2} are duplicates.")
    else:
        print(f"The files {file_path1} and {file_path2} are not duplicates.")

# 示例用法
file_path_1 = 'path/to/file1.txt'
file_path_2 = 'path/to/file2.txt'

check_duplicate_files(file_path_1, file_path_2)

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值