1000字范文,内容丰富有趣,学习的好帮手!
1000字范文 > python office自动化_Python office automation:文档 python 自动化 办公 文件 篇 整理 一键 完成...

python office自动化_Python office automation:文档 python 自动化 办公 文件 篇 整理 一键 完成...

时间:2021-06-26 12:16:15

相关推荐

python office自动化_Python office automation:文档 python 自动化 办公 文件 篇 整理 一键 完成...

文件整理不得不先提一下正则表达式

送上链接:

python :re模块基本用法

一.列出文件夹下的所有文件

os.walk()用法

[ (当前目录列表),(子目录列表),(文件列表)]os.walk(树状结构文件夹名称)

os.walk()返回一个由3个tuple类型的元素组成的列表。

索引值为0的表元素是文件夹名称,据此可以知道当前在处理的文件夹是哪一个。

索引值为1的表元素是下一层文件夹列表,用来了解在此文件夹中还有几个下层文件夹,分别叫什么名字。

索引值为2的元素是本文件夹内所有的文件列表,列出此文件夹中所有的文件名。

由返回值的列表数据,组合出所有往下的树状目录结构的内容。

import os

list_all=[]#初始化一个空列表

for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建文件夹'):

for name in files:

file_path=os.path.join(root,name)#包含路径的文件

file_name=os.path.split(file_path)[-1]

list_all.append(file_name)

print(list_all)

如果文件夹里含有子文件夹,子文件夹有文件。程序无影响,一样可以读取出所有文件名。

二.使用正则re修改文件名

import os

import re

#首先定义规则,如我们需要把所有的图片名提取出来并修改名字

pattern=pile(r'.+\.png')

i=1

for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建文件夹'):

for name in files:

file_path=os.path.join(root,name)#包含路径的文件名

matching=pattern.search(file_path)#匹配图片

if matching:

os.rename(file_path,os.path.split(file_path)[-2]+ '/{}.png'.format(i))

i+=1

print('修改成功')

说明

代码

含义

os.path.split(path)

把路径分割成 dirname 和 basename,返回一个元组

os.rename

传入两个参数,左边旧文件名(包含路径的文件名),第二个参数包含路径的新文件名

os.path.split(file_path)[-2]:[-2]:是获取图片路径(除去名字那部分)

三.批量删除和复制文件

1.批量复制文件

算例:我们将原始文件夹下的PDF复制到新的文件夹:D:\余登武测试1

首先 D:\余登武测试1 ,需要手动新建

import os

import re

#首先定义规则,如我们需要把所有的pdf文件

pattern=pile(r'.+\.pdf')

for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建文件夹'):

for name in files:

file_path=os.path.join(root,name)#包含路径的文件

print(file_path)

matching=pattern.search(file_path)#匹配pdf

if matching:

command_line='copy %s D:\\余登武测试1' % file_path.replace('/','\\')

os.system(command_line)

print('复制成功')

os.system(command_line)调用cmd来执行复制文件。

cmd复制文件命令:

copy 源文件 目的路径

复制好的文件

2.批量删除文件

删除原始文件夹下的pdf

指令os.remove(文件)

import os

import re

#首先定义规则,如我们需要把所有的pdf文件

pattern=pile(r'.+\.pdf')

for root ,dirs,files in os.walk(r'C:\Users\Shineion\Desktop\新建文件夹'):

for name in files:

file_path=os.path.join(root,name)#包含路径的文件

print(file_path)

matching=pattern.search(file_path)#匹配pdf

if matching:

os.remove(file_path)

print('删除成功')

查看原始文件夹,发现pdf文件已删除

电气专业的计算机萌新,写博文不容易。如果你觉得本文对你有用,请点个赞支持下,谢谢。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。