python

python hexdump怎样识别文件类型

小樊
85
2024-12-06 12:44:05
栏目: 编程语言

在Python中,可以使用binascii模块的hexlify()函数将二进制数据转换为十六进制字符串。为了识别文件类型,可以根据十六进制字符串的前几个字节查找对应的文件签名。以下是一个简单的示例,展示了如何使用hexdump识别不同类型的文件:

import binascii

def get_file_type(file_path):
    with open(file_path, 'rb') as f:
        file_start = f.read(16)  # 读取文件的前16个字节
        file_hex = binascii.hexlify(file_start).decode('utf-8')

        # 根据文件签名识别文件类型
        if file_hex.startswith('424d'):  # b'BM' - BMP图像
            return 'BMP'
        elif file_hex.startswith('47494638'):  # b'GIF ' - GIF图像
            return 'GIF'
        elif file_hex.startswith('ff d8 ff'):  # JPEG图像
            return 'JPEG'
        elif file_hex.startswith('89504e47'):  # b'PNG' - PNG图像
            return 'PNG'
        elif file_hex.startswith('4289504e47'):  # b'MIME' - PDF文档
            return 'PDF'
        elif file_hex.startswith(b'\x50\x4b\x03\x04'):  # b'PK\x03\x04' - ZIP文件
            return 'ZIP'
        elif file_hex.startswith(b'\x42\x5a\x68'):  # b'BZ' - BZ2压缩文件
            return 'BZ2'
        else:
            return 'Unknown'

file_path = 'example.txt'
print(f'The file type of {file_path} is: {get_file_type(file_path)}')

这个示例中的get_file_type()函数接受一个文件路径作为参数,读取文件的前16个字节,然后根据这些字节识别文件类型。请注意,这个示例仅支持一些常见的文件类型,你可能需要根据需要扩展它以支持更多的文件类型。

0
看了该问题的人还看了