使用python向png文件插入文本信息(add text chunk to png)

本文介绍了一种使用Python向PNG文件插入文本标识的方法,以避免重复处理已处理过的文件。通过了解PNG文件结构并利用pypng模块,实现了在指定位置插入文本的功能。

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

使用python向png文件插入文本信息(add text chunk to png)

    工作上需要给已经处理过的png文件加上特殊标识,后续再进行处理的时候,可以直接识别到已经处理过了,避免重复处理,所以想到给png文件添加特定的文本信息做标识,在网上搜索良久,没有找到现成的python代码方案,后来在网上看到一篇文章,详细了解了一下png文件结构,再加上前面了解的python pypng模块,自己摸索实现了该功能,下面直接上代码,有需要的同学可参考一下。

import png

TEXT_CHUNK_FLAG = b'tEXt'


def generate_chunk_tuple(type_flag, content):
    return tuple([type_flag, content])


def generate_text_chunk_tuple(str_info):
    type_flag = TEXT_CHUNK_FLAG
    return generate_chunk_tuple(type_flag, bytes(str_info, 'utf-8'))


def insert_text_chunk(target, text, index=1):
    if index < 0:
        raise Exception('The index value {} less than 0!'.format(index))

    reader = png.Reader(filename=target)
    chunks = reader.chunks()
    chunk_list = list(chunks)
    print(chunk_list[0])
    print(chunk_list[1])
    print(chunk_list[2])
    chunk_item = generate_text_chunk_tuple(text)
    chunk_list.insert(index, chunk_item)

    with open(target, 'wb') as dst_file:
        png.write_chunks(dst_file, chunk_list)


def _insert_text_chunk_to_png_test():
    src = r'E:\temp\png\register_05.png'
    insert_text_chunk(src, 'just for test!')


if __name__ == '__main__':
    _insert_text_chunk_to_png_test()
### 使用Python实现批量下载文件并打包压缩 #### 批量下载文件 要实现批量下载文件,可以利用`requests`库来获取网络资源,并将其保存到本地磁盘上。下面是一段用于下载多个URL列表中的文件至指定路径的代码: ```python import os import requests def download_files(file_urls, destination_folder): if not os.path.exists(destination_folder): # 如果不存在则创建目标文件夹 os.makedirs(destination_folder) for url in file_urls: local_filename = os.path.join(destination_folder, url.split('/')[-1]) with requests.get(url, stream=True) as r: r.raise_for_status() with open(local_filename, 'wb') as f: for chunk in r.iter_content(chunk_size=8192): f.write(chunk) print(f'Downloaded {local_filename}') ``` 此函数接收两个参数:一个是包含待下载文件链接的列表`file_urls`;另一个是指定存储位置的目标文件夹名称`destination_folder`。 #### 将已下载的文件打包成ZIP档案 一旦完成了文件的下载工作之后,就可以通过调用内置于标准库内的`zipfile`模块来进行这些文件的归档操作了。这里给出一段能够完成上述任务的小程序片段[^3]: ```python from zipfile import ZipFile import glob def create_zip_archive(source_dir, output_filename='archive.zip'): with ZipFile(output_filename, 'w') as zipObj: files_to_add = glob.glob(os.path.join(source_dir, '*')) for fname in files_to_add: zipObj.write(fname, arcname=os.path.basename(fname)) print(f'Created ZIP archive at {output_filename}') if __name__ == '__main__': urls = [ 'http://example.com/file1.pdf', 'http://example.com/image.png' ] dl_path = './downloads/' download_files(urls, dl_path) create_zip_archive(dl_path) ``` 这段脚本首先定义了一个名为`create_zip_archive()`的新功能,它接受源目录作为输入,并可选地允许自定义输出ZIP文件的名字。接着,在主程序部分指定了几个示例性的远程文件地址以及临时存放所下好的文档的地方——即变量`dl_path`指向的位置。最后依次执行了前面提到过的两步动作:先是从互联网抓取数据存入硬盘里头去,紧接着再把这些新加入的内容统统塞进一个新的压缩包里面。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值