当前位置:
首页 > temp > python入门教程 >
-
《自拍教程78》Python 百度网盘500个文件分割
案例故事
百度网盘非会员大量上传文件,会弹出:“上传文件数量超出500个限制,开通超级会员后可继续上传”,
其实是限制拖入500张相片,并非限制上传500张。
非会员如何将众多文件,分割成500一个的文件夹,不受拖入数量限制呢?
准备阶段
- os.walk()函数,可以树形遍历整个路径下的文件夹列表和文件列表
- Path(路径).parent属性,可以获取该“路径”的父路径
- os.path.relpath("D:\aaa\bbb\ccc",start="D:\aaa")函数,可以返回“bbb\ccc”字符串, 实现路径裁剪。
- os.sep 可以代表任何路径分隔符
- os.rename()函数,可以实现移动功能
-
sys.argv[1] 通过接收“待分割的路径”参数的输入
Python面向对象类形式
# python3.8
# coding=utf-8
import os
import sys
from pathlib import Path
class BaiduPanCutter(object):
'''百度网盘500个文件分割器'''
def __init__(self, root_path, count=500):
self.root_path = root_path
self.count = count
self.folder_file_dict = {} # 文件夹与其文件列表的映射字典
self.get_folders_files() # 获取该根路径下的所有文件夹列表和文件列表
def get_folders_files(self):
'''获取该根路径下的所有文件夹列表和文件列表'''
for folders, _, files in os.walk(self.root_path):
self.folder_file_dict[folders] = files
def _split(self, arr, count):
'''分割文件列表,每500算一份'''
arrs = []
while len(arr) > count:
piece = arr[:count]
arrs.append(piece)
arr = arr[count:]
arrs.append(arr)
return arrs
# 分割文件并放到新的文件去
def cut_file(self):
'''分割并移动到新的文件夹'''
for each_folder in self.folder_file_dict.keys():
num = 1 # 以500为倍数,这是1倍
# 将文件路径(摒弃当前路径)转成字符串,用_隔开
temp_path = os.path.relpath(each_folder, Path(self.root_path).parent)
temp_path = temp_path.replace(os.sep, "_")
print(temp_path)
files_list = self.folder_file_dict[each_folder]
file_group = self._split(files_list, self.count) # 按500来分割
if len(file_group) > 1: # 有超过500个的文件列表
for each_group in file_group: # 遍历每500份的文件列表
new_folder = os.path.join(self.root_path, temp_path + "_" + str(num)) # 新路径
if not os.path.exists(new_folder):
os.mkdir(new_folder)
for each_file in each_group:
old_file = os.path.join(each_folder, each_file)
new_file = os.path.join(new_folder, each_file)
print("正在将%s 移动到 %s" % (old_file, new_file))
os.rename(old_file, new_file)
num = num + 1
else: # 无超过500个的文件列表
new_folder = os.path.join(self.root_path, temp_path) # 新路径
if not os.path.exists(new_folder):
os.mkdir(new_folder)
for each_file in file_group[0]: #
old_file = os.path.join(each_folder, each_file)
new_file = os.path.join(new_folder, each_file)
print("正在将%s 移动到 %s" % (old_file, new_file))
os.rename(old_file, new_file)
if __name__ == '__main__':
try:
arg1 = sys.argv[1]
if os.path.isdir(arg1):
b_obj = BaiduPanCutter(arg1, 500)
b_obj.cut_file()
else:
print("非文件夹,运行方法:python %s 路径文件夹" % sys.argv[0])
except IndexError:
print("未输入待分割的路径文件夹, 运行方法:python %s 路径文件夹" % sys.argv[0])
os.system("pause")
运行方式与效果
运行方式:将以上代码命名为:baidu_pan_500_cutter.py
通过命令:python baidu_pan_500_cutter.py D:\DCIM\Photos 运行
每个文件夹都不会超过500个文件,后续将一个一个的文件夹拖入百度网盘(电脑客户端)即可了。
备注信息
- 本脚本不涉及任何的删除文件或文件夹的操作,不会出现文件丢失情况。
-
兼容非英文的文件夹或文件分割操作。
自拍教程(自动化测试Python教程,武散人编著)
原文链接:https://www.zipython.com/#/detail?id=c6156f71199346f4a10ea5ccbe6aa0b6
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数