Python 获取ResponseContent的文件名

通过网络请求下载的文件,有些时候不想重命名可以直接使用网页所返回的文件名

需要用到两个库

        uuid 负责生成随机的数

        unquote 负责解析编码后的字符

分了两种情况进行处理

1.找得到header 里面文件名
        直接使用文件所返回的文件名

2.找不到header里面的文件名
        自定定义随机的文件名

具体代码

import uuid
from urllib.parse import unquote


# 假设content就是网页返回的response.content内容
content = response.content

# 获取response中的文件名
header = response.headers.get('Content-Disposition')
if header:
    filename = re.findall('filename=(.+)', header)[0]
    filename = unquote(filename)
else:
    filename = f"随机文件名{str(int(time.time() * 1000))}"
    filename = f"随机文件名{str(int(time.time() * 1000))}_{str(uuid.uuid4())[:6]}"
print(filename)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值