0

几天前,我在另一个领域问了一个问题,最后一位朋友 (@emcconville) 帮我编写了一个脚本,用于“在单个文件中恢复每个 JPEG 文件”。现在我意识到这个程序只适用于标准“JFIF”的图像,不能检索“EXIF”标准的图像(数码相机拍摄的图像)。

如何更改程序,使其也可以知道图像中的 Exif 标准?我不熟悉 Python,也不知道它的强大功能。

谢谢

import struct

with open('src.bin', 'rb') as f:
    # Calculate file size.
    f.seek(0, 2)
    total_bytes = f.tell()
    # Rewind to beging.
    f.seek(0)
    file_cursor = f.tell()
    image_cursor = 0

    while file_cursor < total_bytes:
        # Can for start of JPEG.
        if f.read(1) == b"\xFF":
            if f.read(3) == b"\xD8\xFF\xE0":
                print("JPEG FOUND!")
                # Backup and find the size of the image
                f.seek(-8, 1)
                payload_size = struct.unpack('<I', f.read(4))[0]
                # Write image to disk
                d_filename = 'image{0}.jpeg'.format(image_cursor)
                with open(d_filename, 'wb') as d:
                    d.write(f.read(payload_size))
                image_cursor += 1
        file_cursor = f.tell()
4

1 回答 1

4

EXIF 文件的标记为 0xffe1,JFIF 文件的标记为 0xffe0。因此,所有依赖 0xffe0 来检测 JPEG 文件的代码都会丢失所有 EXIF 文件。(从这里)

所以只要改变

if f.read(3) == b"\xD8\xFF\xE0":

if f.read(3) == b"\xD8\xFF\xE1":

如果您想检查这两种情况,请不要再这样使用.read()。取而代之的是

x = f.read(3)
if x in (b"\xD8\xFF\xE0", b"\xD8\xFF\xE1"):
于 2018-08-20T13:27:02.503 回答