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=re.compile(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=re.compile(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=re.compile(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文件已刪除
電氣專業的計算機萌新,寫博文不容易。如果你覺得本文對你有用,請點個贊支持下,謝謝。
總結
以上是生活随笔為你收集整理的python office自动化_Python office automation:文档,python,自动化,办公,文件,篇,整理,一键,完成...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql图片路径varchar大小_M
- 下一篇: mysql后台修改表_mysql之约束以