Python 实现交互式压缩:跟踪每个文件的压缩进度

python 实现交互式压缩:跟踪每个文件的压缩进度

本文介绍如何使用 Python 的 zipfile 模块实现交互式的目录压缩,并在压缩过程中跟踪每个文件的完成情况。通过修改现有的压缩脚本,在压缩完成后打印出已压缩文件的路径,从而提供更友好的用户体验。本文将提供详细的代码示例和步骤,帮助开发者轻松实现这一功能。

实现交互式压缩

现有的 Python 脚本可以方便地将目录下的多个文件夹压缩成独立的 ZIP 文件。为了增强用户体验,我们需要在压缩过程中显示已完成压缩的文件路径。这可以通过在 create_zip 函数中添加一个简单的 print 语句来实现。

以下是修改后的 create_zip 函数:

import osimport zipfileINPUT_FOLDER = 'to_zip'OUTPUT_FOLDER = 'zipped'def create_zip(folder_path, zipped_filepath):    zip_obj = zipfile.ZipFile(zipped_filepath, 'w')  # create a zip file in the required path    for filename in next(os.walk(folder_path))[2]: # loop over all the file in this folder        zip_obj.write(            os.path.join(folder_path, filename),  # get the full path of the current file            filename,  # file path in the archive: we put all in the root of the archive            compress_type=zipfile.ZIP_DEFLATED        )    zip_obj.close()    print(f'Zipped: {zipped_filepath}') # Added print statementdef zip_subfolders(input_folder, output_folder):    os.makedirs(output_folder, exist_ok=True)  # create output folder if it does not exist    for folder_name in next(os.walk(input_folder))[1]:  # loop over all the folders in your input folder        zipped_filepath = os.path.join(output_folder, f'{folder_name}.zip')  # create the path for the output zip file for this folder        curr_folder_path = os.path.join(input_folder, folder_name)  # get the full path of the current folder        create_zip(curr_folder_path, zipped_filepath)  # create the zip file and put in the right locationif __name__ == '__main__':    zip_subfolders(INPUT_FOLDER, OUTPUT_FOLDER)

在上述代码中,我们在 create_zip 函数的 zip_obj.close() 之后添加了 print(f’Zipped: {zipped_filepath}’) 语句。这将在每个 ZIP 文件创建完成后,立即打印出该文件的完整路径。

立即学习“Python免费学习笔记(深入)”;

运行示例

为了测试这段代码,你需要创建两个目录:to_zip(INPUT_FOLDER)和 zipped(OUTPUT_FOLDER)。在 to_zip 目录下,创建几个子目录,每个子目录中包含一些文件。运行脚本后,你将在控制台中看到每个 ZIP 文件的压缩进度。

例如,如果 to_zip 目录下包含名为 folder1 和 folder2 的两个子目录,运行脚本后,你将看到如下输出:

Zipped: zipped/folder1.zipZipped: zipped/folder2.zip

注意事项

确保 INPUT_FOLDER 和 OUTPUT_FOLDER 变量的值与实际的目录结构相匹配。如果 OUTPUT_FOLDER 目录不存在,zip_subfolders 函数会自动创建该目录。此方法仅打印每个 ZIP 文件的完成情况。如果需要更详细的进度信息(例如,每个文件的压缩进度),则需要更复杂的实现,可能涉及到自定义的进度条或回调函数

总结

通过在 create_zip 函数中添加一个简单的 print 语句,我们可以轻松地实现交互式的目录压缩,并向用户提供有关压缩进度的反馈。这种方法简单有效,可以显著提升用户体验。对于更复杂的进度跟踪需求,可能需要更高级的技术,例如使用 tqdm 库创建进度条。

以上就是Python 实现交互式压缩:跟踪每个文件的压缩进度的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1375211.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 14:48:58
下一篇 2025年12月14日 14:49:03

相关推荐

  • python如何截取字符串后几位

    使用切片操作 s[-n:] 可截取字符串后 n 位,如 s=”HelloWorld”,s[-3:] 输出 rld;若长度不足则自动从开头截取,支持变量动态控制位数。 在 Python 中,截取字符串后几位可以使用切片(slice)操作,这是最常用也最简单的方法。 使用切片截取…

    好文分享 2025年12月14日
    000
  • Mininet自定义脚本连接OpenDaylight控制器:本地部署配置详解

    本教程旨在解决Mininet自定义Python脚本在本地环境中无法正确连接OpenDaylight控制器的问题,即使通过mn命令行工具能够成功连接。核心在于阐明Mininet初始化时控制器和交换机类型配置的重要性,并提供通过修改Mininet构造函数参数来确保网络拓扑与远程控制器正确建立连接的解决方…

    2025年12月14日
    000
  • Mininet与OpenDaylight本地控制器连接教程:脚本化集成实践

    本教程旨在解决Mininet模拟器与OpenDaylight控制器在同一本地环境中,通过Python脚本进行连接时遇到的常见问题。文章深入分析了为何直接使用mn命令可以成功连接,而自定义脚本可能失败的原因,并提供了一个精确的解决方案。核心在于Mininet初始化时,需显式指定RemoteContro…

    2025年12月14日
    000
  • Python 实现交互式压缩:实时追踪文件压缩进度

    本文将指导你如何使用 Python 实现交互式压缩,并在压缩过程中实时显示已完成压缩的文件路径。通过简单的代码修改,你可以在控制台中看到每个文件压缩完成后的提示信息,从而更清晰地了解压缩进度。 实现交互式压缩 原始代码提供了一个批量压缩目录下子文件夹为独立 zip 文件的功能。为了实现交互式体验,我…

    2025年12月14日
    000
  • Pandas DataFrame日期范围筛选教程

    本教程详细介绍了如何在Pandas DataFrame中高效地进行日期范围筛选。我们将首先强调将日期列正确转换为datetime类型的重要性,然后通过实际代码示例,演示如何利用布尔索引和比较运算符,根据单个日期或特定日期区间来提取所需数据,并提供最佳实践以避免常见错误。 1. 引言与常见问题 在数据…

    2025年12月14日
    000
  • python中值传递和引用传递的区别

    Python采用传对象引用方式,不可变对象(如整数、字符串)在函数内修改不影响原变量,因赋值会创建新对象;可变对象(如列表、字典)可通过方法修改内容,影响原始对象,但重新赋值则断开引用。 在 Python 中,并没有像 C++ 或 Java 那样明确的“值传递”和“引用传递”的分类。Python 的…

    2025年12月14日
    000
  • Python中检查文件可写性的高效策略

    本教程探讨了在Python中检查文件是否可写而不实际创建文件的高效策略。文章首先指出直接尝试打开文件并删除的潜在问题,随后介绍了两种主要方法:使用os.access()函数进行权限检查,以及更推荐的“请求原谅而非许可”(EAFP)原则,即通过try-except PermissionError结构直…

    2025年12月14日
    000
  • Python中检查文件可写性的有效方法

    本文探讨了在Python中检查文件可写性而不实际写入的有效方法。我们将介绍如何利用os.access()函数进行权限判断,以及在计划立即打开文件时,通过try-except捕获PermissionError的更健壮实践,旨在帮助开发者避免不必要的临时文件和潜在的竞争条件,确保文件操作的可靠性。 在p…

    2025年12月14日
    000
  • 解决Python脚本无响应:理解无限循环与正确缩进

    本文探讨了Python脚本运行时出现空白屏幕或无响应的常见问题,主要归因于不当的循环结构和缩进。通过分析一个简单的生命值问答游戏示例,我们将深入理解Python中while True循环的正确使用方式,以及缩进如何决定代码块的执行范围。掌握这些核心概念对于编写健壮、可控的Python程序至关重要,能…

    2025年12月14日
    000
  • Python AES 加密解密后文本为空的解决方案

    本文针对 Python 中使用 Crypto 库进行 AES 加密解密时出现解密后文本为空的问题,提供了一种解决方案。通过分析代码,指出问题在于密钥处理方式,并提供修正后的代码示例,确保加密解密流程的正确性。同时,本文还包含完整的加密解密示例代码,方便读者理解和应用。 在使用 Python 的 Cr…

    2025年12月14日
    000
  • Python AES 加密解密后为空字符串问题的解决

    本文旨在解决在使用 Python 的 Crypto 库进行 AES 加密和解密时,解密后得到空字符串的问题。通过分析常见原因和提供修复后的代码示例,帮助开发者正确实现 AES 加密解密功能,确保数据的安全传输和存储。 AES(Advanced Encryption Standard)是一种广泛使用的…

    2025年12月14日
    000
  • 创建 TensorFlow 自定义优化器:获取梯度和变量向量

    本文档旨在指导开发者如何在 TensorFlow 中创建自定义优化器。我们将重点介绍如何获取每次迭代中的梯度和变量向量,并正确地更新这些值。通过继承 tf.keras.optimizers.Optimizer 类,并重写关键方法,开发者可以灵活地实现自己的优化算法,从而更好地控制模型的训练过程。本文…

    2025年12月14日
    000
  • 在 TensorFlow 中构建自定义优化器

    本文档旨在指导开发者如何在 TensorFlow 中创建自定义优化算法。我们将深入探讨如何获取每次迭代的当前点向量 x 和梯度向量 g,以及如何更新 x 并将更新后的值设置回模型。通过一个具体的示例,我们将展示如何修改梯度形状以适应自定义优化算法的需求,并提供构建和应用自定义优化器的完整流程。 自定…

    2025年12月14日
    000
  • Python列表中有哪些索引

    Python列表支持四种索引方式:1. 正数索引从0开始访问元素,如my_list[0]获取第一个元素;2. 负数索引从-1起从末尾反向访问,如my_list[-1]获取最后一个元素;3. 切片索引用[start:end:step]获取子列表,支持步长与反转;4. 动态索引通过index()方法查找…

    2025年12月14日
    000
  • TensorFlow自定义优化器教程:深入理解梯度操作

    本文旨在指导开发者如何在TensorFlow中创建自定义优化器,重点讲解如何获取每次迭代的当前点向量和梯度向量,并进行更新。通过实例代码,详细解释了梯度扁平化处理的重要性,以及如何在自定义优化器中正确更新模型参数,从而实现对神经网络优化算法的灵活控制。 在TensorFlow中,自定义优化器能够让我…

    2025年12月14日
    000
  • 高效处理 Python 异步操作中的异常

    本文旨在提供一种在 Python 的 asyncio 框架下,高效处理异步操作中异常的方法。重点在于如何在单个任务发生异常时,避免影响其他并发任务的执行,从而保证程序的健壮性和稳定性。我们将通过代码示例展示如何在异步函数内部进行异常处理,确保即使出现错误,程序也能继续执行。 在 Python 中使用…

    2025年12月14日
    000
  • Python异步操作中的高效错误处理

    本文旨在提供在Python中使用asyncio进行异步操作时,如何高效处理错误的实用指南。通过将错误处理逻辑嵌入到每个独立的异步任务中,可以确保即使某个任务失败,其他任务也能继续执行,从而提高程序的整体健壮性和可靠性。本文将提供示例代码,演示如何在asyncio中实现这种错误处理策略,并讨论相关的注…

    2025年12月14日
    000
  • 通过值搜索Python字典并返回相关值

    本文旨在提供一种通过Python字典的值来查找相关信息的方法。我们将探讨如何遍历字典,检查目标值是否存在,并返回与该值相关的其他值。通过示例代码,你将学会如何根据元素名称、符号、原子序数或原子量来查找化学元素的相关信息。同时,我们也会讨论如何保持返回值的顺序,以及在实际应用中需要注意的事项。 在许多…

    2025年12月14日
    000
  • Python字典高效过滤:创建满足特定条件的新字典

    本文将介绍如何高效地根据特定条件过滤Python字典,并创建两个新的字典。原始字典中的每个键值对将根据值中是否包含特定字符串而被分配到两个新字典中的一个。我们将使用 items() 方法遍历字典,并结合 any() 函数进行条件判断,以实现简洁高效的过滤。 使用 items() 方法和 any() …

    2025年12月14日
    000
  • 使用 Python 过滤字典创建新字典的实用指南

    本文旨在指导读者如何根据特定条件,高效地从一个Python字典中创建两个新的字典。通过迭代原始字典的键值对,并结合any()函数进行条件判断,我们可以将符合条件的键值对分别添加到两个目标字典中,从而实现字典的过滤和拆分。本文提供清晰的代码示例和详细的解释,帮助读者理解和应用这一技术。 在Python…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信