利用py批量下载文件,并且给文件分类

py 批量下载文件 并且分类

因为微信小程序的云开发,并没有类似于批量导出的函数,但是又想要将云存储中的相关文件批量下载下来。

思路

一、

尝试用nodejs遍历文件夹下载之后,发现
1、没办法判断云服务器的存储路径
2、nodejs添加图片并打包是要把图片转换为base64编码的。

二、

将所有要下载的文件的云存储地址存储到数据库中,在前端将其转换为http的url地址,整理到xlsx文件中。下载下来,再用py批量下载,并且实现分类。

1.首先将数据库中的关于要下载的文件的url地址利用js导出为一个excel文件。
在这里插入图片描述

2.读取xlsx,使用了py中的xlrd包。读取文件的第一列就行了。col1_values是一个list对象。

def main():
    book = xlrd.open_workbook('./文件下载地址.xlsx')
    sheet1 = book.sheets()[0]
    col1_values = sheet1.col_values(0)
    download(col1_values)

3.将col1_values这个list对象传入download函数进行下载。使用了split对url进行分割,并且跟据分割的结果创建文件夹实现分类。
一定要注意记得加上 ’ \ '

def download(list):
    # 通过正则匹配
    pic_url = list[1:]  # 去除掉tempurl
    for key in pic_url:
        print("开始下载:" + key + "\r\n")
        try:
            pic = requests.get(key, timeout=5)
        except requests.exceptions.ConnectionError:
            print('下载失败')
            continue
        # 保存图片路径
        dir = key.split('/')[3]  # 学号+姓名 命名文件夹
        mkdir(folder + '/' + dir)  # 创建文件夹
        dir1 = key.split('/')[4]  # 内容 命名文件
        dir = folder + '/' + dir + '/' + dir1  # 下载文件的保存路径
        fp = open(dir, 'wb')
        fp.write(pic.content)
        fp.close()
  1. 创建文件夹
# 获取此py文件路径,在此路径中保存文件
folder = os.getcwd()
print(folder)

# 创建文件夹
def mkdir(path):
    folder = os.path.exists(path)

    if not folder:  # 判断是否存在文件夹如果不存在则创建为文件夹
        os.makedirs(path)  # makedirs 创建文件时如果路径不存在会创建这个路径

最终效果

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
我们可以使用Python编程语言结合高德API来实现将Excel表中的地址批量转换为高德经纬度。 首先,我们需要安装pandas和requests库来处理Excel表和发送API请求。可以使用以下命令安装这些库: ```python pip install pandas requests ``` 然后,我们需要从Excel中读取地址数据并进行转换。可以使用以下代码来实现: ```python import pandas as pd import requests # 读取Excel文件 data = pd.read_excel('地址表.xlsx') # 遍历每一行数据 for index, row in data.iterrows(): address = row['地址'] # 发送地址转换请求 url = 'https://restapi.amap.com/v3/geocode/geo' params = {'key': '你的高德API密钥', 'address': address} response = requests.get(url, params=params) # 解析响应并获取经纬度信息 result = response.json() if result['status'] == '1' and int(result['count']) >= 1: geocode = result['geocodes'][0] location = geocode['location'] # 更新Excel表中的经纬度字段 data.at[index, '经纬度'] = location # 保存修改后的Excel文件 data.to_excel('经纬度表.xlsx', index=False) ``` 在上面的代码中,我们首先使用pandas库的`read_excel`函数读取Excel文件,并使用`iterrows`方法遍历每一行数据。然后,我们将地址数据传递给高德API的`geocode/geo`接口,并将响应中的经纬度信息更新到Excel表中的相应字段。最后,我们使用pandas的`to_excel`方法保存修改后的Excel文件。 需要注意的是,你需要将代码中的`你的高德API密钥`替换为你自己的高德API密钥,以便能够成功发送地址转换请求。此外,你还需要将代码中的`地址表.xlsx`替换为你自己的Excel文件名,以及将`经纬度表.xlsx`替换为你希望保存经纬度数据的Excel文件名。 希望以上信息能够帮助你使用Python和高德API批量将Excel表中的地址转换为高德经纬度。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值