python 下载文件并打包

2 篇文章 0 订阅

功能

根据附件地址去下载附件,然后打包zip,返回打包文件名
主要利用request和zip模块

实现

1.根据附件url地址request去下载到本地

        try:
            res = requests.get(data[0], stream=True, timeout=10, headers=headers)
            with open(file, "wb") as fd:
                for chunk in res.iter_content(chunk_size=1024):
                    fd.write(chunk)
        except Exception:
            print("保存附件失败:", str(data), file)
            print(traceback.format_exc())
            if logger:
                logger.error("保存附件失败: %s", traceback.format_exc())

2.zipfile模块打包下载文件

zipfile_name = folder + '.zip'  # 压缩包和文件夹同名
    with ZipFile(zipfile_name, 'w') as zfile:  # 以写入模式创建压缩包
        for foldername, subfolders, files in os.walk(folder):  # 遍历文件夹
            # zfile.write(foldername)
            for i in files:
                zfile.write(os.path.join(foldername, i), i)
    return zipfile_name

具体代码

import os
import shutil
import traceback

import requests
from zipfile import ZipFile


headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36'
}

# 打包目录为zip文件(未压缩)
def make_zip(folder):
    zipfile_name = folder + '.zip'  # 压缩包和文件夹同名
    with ZipFile(zipfile_name, 'w') as zfile:  # 以写入模式创建压缩包
        for foldername, subfolders, files in os.walk(folder):  # 遍历文件夹
            # zfile.write(foldername)
            for i in files:
                zfile.write(os.path.join(foldername, i), i)
    return zipfile_name


def get_file(dir, data):
    name = data[1]
    if not name:
        array = data[0].split("/")
        name = array[-1]
    if name.find(".") == -1:
        array = data[0].split(".")
        name += "." + array[-1]
    file = dir + name
    return file


def zip_attachment(path, attachments, logger=None):
    if len(attachments) == 0:
        return ""
    # download file
    dir = path + "/"
    if not os.path.exists(dir):
        os.mkdir(dir)
    for data in attachments:
        file = get_file(dir, data)
        try:
            res = requests.get(data[0], stream=True, timeout=10, headers=headers)
            with open(file, "wb") as fd:
                for chunk in res.iter_content(chunk_size=1024):
                    fd.write(chunk)
        except Exception:
            print("保存附件失败:", str(data), file)
            print(traceback.format_exc())
            if logger:
                logger.error("保存附件失败: %s", traceback.format_exc())
    # zip directory
    zipFile = make_zip(path)
    # remove file
    shutil.rmtree(path)
    return zipFile.split("/")[-1]

调用

	# 附件存路径
	path = "D:/data/"
	# 附件url列表
	attachments = ['http://www.xxx.com/ahdad/asdas.doc']
	zip_attachment(path, attachments)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Python是一种流行的编程语言,提供了丰富的库和工具,可以用来完成各种任务。在Python中进行打包下载文件的操作也非常简单。 首先,我们可以使用`urllib`库中的`urlretrieve`函数来下载文件。该函数接受两个参数,第一个参数是文件的URL,第二个参数是保存文件的本地路径。 下面是一个使用`urlretrieve`函数下载文件的示例: ```python import urllib url = "http://example.com/file.txt" # 文件的URL local_path = "path/to/save/file.txt" # 保存文件的本地路径 urllib.request.urlretrieve(url, local_path) # 下载文件 ``` 这段代码将会从给定的URL下载文件,并保存到本地路径中。 另外,如果你想使用Python打包文件,你可以使用`shutil`库中的`make_archive`函数。这个函数允许你将一个目录打包成一个压缩文件。 下面是一个使用`make_archive`函数打包文件的示例: ```python import shutil directory = "path/to/directory" # 要打包的目录 output_path = "path/to/save/archive.zip" # 保存压缩文件的路径 shutil.make_archive(output_path, "zip", directory) # 打包目录为zip文件 ``` 这段代码将会把给定的目录打包成一个zip文件,并保存到指定的路径中。 总之,使用Python进行打包下载文件非常简单。通过使用`urllib`库中的`urlretrieve`函数,我们可以下载文件;而使用`shutil`库中的`make_archive`函数可以方便地打包目录。这些功能使得Python成为处理文件的强大工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tobin liao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值