python打包压缩文件夹zip+组装文件夹
无意间想到的一个需求,然后就顺手写了写,留下来,方便以后用
列表版:(基本没用,仅提供思路,字典版稍微改动可以直接用)
大体需求:
把重复的文件名进行改名,达到浏览器下载相同文件的效果
下载完成后再把文件夹和目录名删掉
import os
import zipfile
import shutil
import re def make_zip(source_dir, output_filename):
zipf = zipfile.ZipFile(output_filename, 'w', zipfile.ZIP_DEFLATED)
pre_len = len(os.path.dirname(source_dir))
for parent, dirnames, filenames in os.walk(source_dir):
for filename in filenames:
pathfile = os.path.join(parent, filename)
arcname = pathfile[pre_len:].strip(os.path.sep) # 相对路径
zipf.write(pathfile, arcname)
zipf.close() dir_name = "files"
os.makedirs(dir_name)
file_names = ["文件1","文件2","文件1","文件1","文件1","wenjian1"]
file_names_sorted = sorted(file_names)
file_new_names = []
prog = re.compile(r".*\((\d+)\)$")
for file_name in file_names_sorted:
if file_name in file_new_names:
if prog.match(file_new_names[-1]):
file_name = file_name + "(%s)" % (int(prog.match(file_new_names[-1]).group(1))+1)
else:
file_name = file_name + "(1)"
file_new_names.append(file_name) for file_new_name in file_new_names:
file_path = os.path.join(dir_name, file_new_name)
with open(file_path+'.py', mode="w", encoding="utf-8")as f:
f.write("print('hello world!')") shutil.rmtree("files")
os.remove("files")
字典版:
关键问题:tornado提供下载,对重复的文件名进行重命名(和浏览器类似)
import os
import zipfile
import shutil
import re
import tornado.web class FileDownLoadHandler(tornado.web.RequestHandler):
def post(self, *args, **kwargs):
def make_zip(source_dir, output_filename):
zipf = zipfile.ZipFile(output_filename, 'w', zipfile.ZIP_DEFLATED)
pre_len = len(os.path.dirname(source_dir))
for parent, dirnames, filenames in os.walk(source_dir):
for filename in filenames:
pathfile = os.path.join(parent, filename)
arcname = pathfile[pre_len:].strip(os.path.sep) # 相对路径
zipf.write(pathfile, arcname)
zipf.close() # dir_name和file_infos都应该从数据库取
dir_name = "新建文件夹"
os.makedirs(dir_name)
file_infos = [{'file_content': 'print("Hello World!")', 'file_name': '文件1'},
{'file_content': 'print("Hello World!")', 'file_name': '文件2'},
{'file_content': 'print("Hello World!")', 'file_name': '文件1'}]
print(file_infos)
file_infos_sorted = sorted(file_infos, key=lambda item: item["file_name"])
prog = re.compile(r".*\((\d+)\)$")
print(file_infos_sorted)
file_new_infos = []
file_names_set = set()
for file_info in file_infos_sorted:
if file_info["file_name"] in file_names_set:
if prog.match(file_new_infos[-1]["file_name"]):
file_info["file_name"] = file_info["file_name"] + "(%s)" % (
int(prog.match(file_new_infos[-1]["file_name"]).group(1)) + 1)
else:
file_info["file_name"] = file_info["file_name"] + "(1)"
else:
file_names_set.add(file_info["file_name"])
file_new_infos.append(file_info) for file_new_info in file_new_infos:
file_path = os.path.join(dir_name, file_new_info["file_name"])
with open(file_path + ".py", mode="w", encoding="utf-8")as f:
f.write(file_new_info["file_content"]) target_name = dir_name + ".zip"
make_zip(dir_name, target_name) # 打包加压缩 # 下载
self.set_header('Content-Type', 'application/octet-stream')
self.set_header('Content-Disposition', ('attachment; filename=%s' % target_name).encode("utf-8"))
buf_size = 4096
with open(target_name, "rb")as f:
while True:
data = f.read(buf_size)
if not data:
break
self.write(data)
self.finish() shutil.rmtree(dir_name)
os.remove(target_name)
才发现自己是真的菜,无意间问了一个java的同事,他们说Java可以直接写如zip流,然后找到了python的写入文件流的方式
def test_zip(self):
import zipfile, tempfile, os
try:
file_name = tempfile.mktemp(suffix=".zip") # mktemp方法慎用
with zipfile.ZipFile(file_name, 'w', zipfile.ZIP_DEFLATED) as zf:
for i in range(5):
zf.writestr("文件名%s" % i, """print('文件内容')""")
# 这里接着就是下载逻辑了,和上面的一样,就不重复写了
finally:
os.remove(file_name)
python打包压缩文件夹zip+组装文件夹的更多相关文章
- 【转】打包 压缩 命令tar zip
https://www.cnblogs.com/centos2017/p/7896807.html tar语法 #压缩tar -czvf ***.tar.gztar -cjvf ***.tar.bz2 ...
- 打包 压缩 命令tar zip
tar语法 #压缩tar -czvf ***.tar.gztar -cjvf ***.tar.bz2#解压缩tar -xzvf ***.tar.gztar -xjvf ***.tar.bz2 tar ...
- linux 学习笔记 显示压缩文件 gong.zip 的文件内容
#zip -v gong zip zip info: xxx >删除压缩文件中俄smart.txt 文件 #zip -d gong.zip smart.txt deleting:smart.tx ...
- linux tar打包压缩排除某个目录或文件
用tar打包时想剔除打包目录中的某个子目录或文件: 比如你想打包/home这个目录,但是/home/afish/目录和/home/www/afish.php文件你都不想打包,方法是: tar -zcv ...
- Linux常用命令2--用户问题、文件的打包压缩
Linux常用命令 如何进行用户和群组的创建和更改 [1]groupadd:用于创建新的群组. 语法:groupadd [-option] 用户名:其常用参数有:-g groupadd -g 555 ...
- ICSharpCode.SharpZipLib工具压缩与解压缩zip文件
using System; using System.Collections.Generic; using System.IO; using System.Text; using ICSharpCod ...
- webpack打包后不能调用,改用uglifyjs打包压缩
背景: 项目基于原生js,没用到任何脚手架和框架,但也需要打包压缩. 项目的js中声明了一些全局变量 供其他js调用. 这时候如果用webpack打包,基于webpack特性,会嵌套一层大函数,会将j ...
- Python打包文件夹的方法小结(zip,tar,tar.gz等)
本文实例讲述了Python打包文件夹的方法.分享给大家供大家参考,具体如下: 一.zip ? 1 2 3 4 5 6 7 8 9 10 11 import os, zipfile #打包目录为zip文 ...
- PHP扩展类ZipArchive实现压缩解压Zip文件和文件打包下载
文章转载自:https://my.oschina.net/junn/blog/104464 PHP ZipArchive 是PHP自带的扩展类,可以轻松实现ZIP文件的压缩和解压,使用前首先要确保PH ...
随机推荐
- ibatis annotations 注解方式返回刚插入的自增长主键ID的值
mybatis提供了注解方式编写sql,省去了配置并编写xml mapper文件的麻烦,今天遇到了获取自增长主键返回值的问题,发现相关问答比较少,还好最后还是圆满解决了,现把重点记录一下,解决问题的关 ...
- c# 根据唯一码,存缓存 实现12小时内 阅读量+1
需求:某一个详细页面需要实现用户 12小时内阅读量+1, 实现思路;得到一个唯一码的机器码,不管是否用户登录了 都有这个码,然后存到缓存里面 最后判断时间+12小时 是否超过当前时间 string ...
- Knowledge point
静态网页的特点:以htm.html.sbtml.xml.js.css等为后缀扩展名. 1)程序在客户浏览器端解析,不需要读取数据库,性能和效率较高: 2)后端没有数据库支持,所以和用户的交互性差,功能 ...
- gdb命令调试技巧
gdb命令调试技巧 一.信息显示1.显示gdb版本 (gdb) show version2.显示gdb版权 (gdb) show version or show warranty3.启动时不显示提示信 ...
- [译]Android view 测量布局和绘制的流程
原文链接 创造优秀的用户体验是我们开发者的主要目标之一.为此, 我们首先要了解系统是如何工作的, 这样我们才可以更好的与系统配合, 从它的优点中获益, 规避它的缺陷. 之前关于Android渲染过程的 ...
- 大数据 --> 淘宝异构数据源数据交换工具 DataX
淘宝异构数据源数据交换工具 DataX DataX是什么? DataX是一个在异构的数据库/文件系统之间高速交换数据的工具,实现了在任意的数据处理系统(RDBMS/Hdfs/Local filesys ...
- 网络通信 --> TCP三次握手和四次挥手
TCP三次握手和四次挥手 建立TCP需要三次握手才能建立,而断开连接则需要四次握手.整个过程如下图所示: 一.TCP报文格式 如下图: (1)序号:Seq序号,占32位,用来标识从TCP源端向目的端发 ...
- Android开发心得-使用File ExPlorer无法访问系统内部文件
问题:本机在获得ROOT权限后,使用Eclipse自带的File Explorer访问/data/data下各APP的存储文件,均无法打开.更换另外一个设备后,情况正常.Sumsung的有些机型在获得 ...
- Spring MVC的handlermapping之BeanNameUrlHandlerMapping初始化
先介绍一下: BeanNameUrlHandlerMapping是基于配置文件的方式; 所有处理器需要在XML文件中,以Bean的形式配置. 缺点:配置繁琐; 如果多个URL对应同一个处理器,那么需要 ...
- 2018最新版本Sublime Text3注册码(仅供测试交流使用)
-– BEGIN LICENSE -– TwitterInc 200 User License EA7E-890007 1D77F72E 390CDD93 4DCBA022 FAF60790 61AA ...