python计算文件md5值

枫铃3年前 (2021-09-30)Python204

较小文件处理方法:

import hashlib
import os

def GetSmallFile(file_path):
  md5 = None
  if os.path.isfile(file_path):
    f = open(file_path,'rb')
    md5_obj = hashlib.md5()
    md5_obj.update(f.read())
    hash_code = md5_obj.hexdigest()
    f.close()
    md5 = str(hash_code).lower()
  return md5

md5 = GetSmallFile(file_path)print(md5)

较大文件处理方法:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import hashlib
import os

"""
    获取文件Md5值
    file_path = r'/opt/code/my_code/zk_css/zk_css.cnf'
    md5_02 = GetBigFileMd5Value(file_path)

"""


def GetBigFileMd5Value(file_path):
    f = open(file_path, 'rb')
    md5_obj = hashlib.md5()
    while True:
        d = f.read(8096)
        if not d:
            break
        md5_obj.update(d)
    hash_code = md5_obj.hexdigest()
    f.close()
    md5 = str(hash_code).lower()
    return md5

报错、解决方案

TypeError: Unicode-objects must be encoded before hashing

>>> a = "张三李四王五赵六"
>>> md5_obj.update(a)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: Unicode-objects must be encoded before hashing

方法:

>>> md5_obj.update(a.encode("utf-8"))
>>> md5_obj.hexdigest()
'deeea258a3f22c6dd9307e4dd2b6c016'

相关文章

将Python字符串生成PDF

将Python字符串生成PDF

笔者在今天的工作中,遇到了一个需求,那就是如何将Python字符串生成PDF。比如,需要把Python字符串‘这是测...

python压平嵌套列表

list 是 Python 中使用最频繁的数据类型, 标准库里面有丰富的函数可以使用。 不过,如果把多维列表转换成一维列表(不知道这种需求多不多...

四种python 单继承的实现方式

第一类单继承的实现&#x...

python列表多重赋值

1.列表多重赋值常规方法...

Python中的defaultdict方法

python中的dict...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。