
來源:早起Python
作者:劉早起
大家好,我是早起。
在過去的半年內,我總共發布了超過了40篇 「Python辦公自動化」文章,不知道大家有沒有發現,有一些模塊、一些代碼會頻繁出現。而os、shutil、glob基本是每篇都會出現。
在寫了幾十篇文章后,我將一些辦公自動化常用操作的代碼單獨整理出來,大家拿走就可以用在自己的腳本中!
批量操作的前提就是對文件夾進行遍歷,使用os模塊可以輕松的遍歷文件夾,os.walk 遍歷后產生三個參數:
“當前文件夾路徑包含文件夾名稱[列表形式]包含文件名稱[列表形式]”
代碼如下,大家可以根據自己的路徑進行修改
import os
for dirpath, dirnames, filenames in os.walk(r'C:Program Files (x86)'):
print(f'打開文件夾{dirpath}') # 當前文件夾路徑 if dirnames:
print(dirnames) # 包含文件夾名稱[列表形式] if filenames:
print(filenames) # 包含文件名稱[列表形式] print('-' * 10)
當手上的需求明確有獲取給定路徑各級文件夾下所有符合條件的文件,并進行相應的批處理操作時,即可使用 os.walk
有時我們需要判斷一個目錄下是否存在文件也可以使用os模塊。
給定一個目標路徑 path ,通過一行代碼就能夠判斷這是文件還是文件夾路徑
import os path = 'xxx' print(os.path.isfile(path))
os.path.basename 可以直接從絕對路徑中獲取最后的文件名,當然如果用傳統的字符串切割方式也可以,即 path.split('')[-1]
import os path = 'xxx' print(os.path.basename)
創建文件夾的代碼非常常用,因為往往生成的新文件都希望有個新的文件夾存儲,代碼如下:
import os dirpath = 'xxx' os.mkdir(dirpath)
但是,如果希望創建的文件夾已經存在,再運行 os.mkdir() 則會報錯而終止代碼。為了避免這一情況的發生,可以在創建文件夾之前先判斷文件夾是否存在。
用到的代碼是 os.path.exists,只有當路徑不存在(即 os.path.exists 返回的結果是 False 時),才會創建:
import os dirpath = 'xxx' if not os.path.exists(dirpath):
os.mkdir(dirpath)
獲取桌面路徑也是非常常用的操作,可以使用os.path.join(os.path.expanduser("~"), 'Desktop') 獲取桌面的絕對路徑。
這樣做的好處是可以把數據放在桌面上,在不同的電腦上都能調用代碼對數據進行處理。如果是在一條電腦上把桌面路徑固定在字符串中,則換一臺電腦就必須修改桌面路徑。代碼如下:
import os desktop_path = os.path.join(os.path.expanduser("~"), 'Desktop') print(desktop_path)
當然把上面的代碼包裝成一個函數 GetDesktopPath() 需要時調用它會更加方便
import os def GetDesktopPath():
return os.path.join(os.path.expanduser("~"), 'Desktop')
需要用到 os.rename() 方法,下面的代碼示例中分別演示如何重命名文件和文件夾
import os os.rename('practice.txt', 'practice_rename.txt') #
重命名文件 os.rename('文件夾1', '文件夾2') # 重命名文件夾
除了前面的 os.walk 之外,有其他的 os 模塊下方法可完成獲取指定路徑的全部或符合條件的文件(非遍歷各級文件夾的需求),還可以使用下面兩個代碼 第一種用到的方法是os.scandir(),使用如下:
import os path = 'xxx' for file in os.scandir(path):
print(file.name, file.path)
上面代碼最后輸出的是 給定路徑下各內容的名字、絕對路徑第二種方法使用 os.listdir(),它比 os.scandir() 簡單一些,可直接調用輸出名稱而非路徑:
import os path = 'xxx' for file in os.listdir(path):
print(file)
shutil也是經常出現在辦公自動化場景中的模塊,我常用的就是移動文件/文件夾。
需要用到shutil.move 方法,下面的代碼示例中分別演示如何移動文件和文件夾:
import shutil
shutil.move(r'.practice.txt', r'.文件夾1/')
shutil.move(r'.practice.txt', r'.文件夾1/new.txt')
注意到上面后兩行代碼的區別嗎?前一行是將目標文件移動到目標文件夾里,而后一行,在將目標文件移動到目標文件夾里的同時,能夠對其進行重命名
也就是說,如果我們需要移動某個或某些文件到新的文件夾,并且需重命名文件,則我們并不需要用 os.rename 先命名文件再用 shutil.move 將其移動的指定文件夾,而是可以用 shutil.move 一步到位。
最后要介紹的是glob模塊,也是辦公自動化必須要掌握的一個模塊,同樣可以用于批處理文件。
glob 最重要的功能就是搜索獲取同一級或者各子級下符合條件的文件(絕對路徑),非常適合寫批處理的代碼。
有時候我們需要對大量文件進行相同操作,在寫完針對一份文件的操作后,只需要加上幾行代碼,就可以完成批處理全部文件的工作。大致代碼框架如下:
import glob
for file in glob.glob('**/*', recursive=True):
print(file)
glob.glob() 是一個非常重要的方法,能夠獲取給定路徑下文件的絕對路徑,并且接受「通配符」搜索,大大拓寬了靈活程度,* 表示任意字符長度,**/* 的使用表示用通配符指代給定路徑下的任何一層,recursive 參數允許遍歷搜索。
以上就是我為大家整理的十個常用操作的代碼,大部分都是可以通用的,大家可以收藏本文,并在需要進行相關操作的時候可以直接復制粘貼使用。
另外也希望大家在自己寫代碼、讀別人代碼時,可以多去思考哪些函數/代碼片段是可以為我所用,這樣才會進步的更快!
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
2025 年,數據如同數字時代的 DNA,編碼著人類社會的未來圖景,驅動著商業時代的運轉。從全球互聯網用戶每天產生的2.5億TB數據, ...
2025-05-27CDA數據分析師證書考試體系(更新于2025年05月22日)
2025-05-26解碼數據基因:從數字敏感度到邏輯思維 每當看到超市貨架上商品的排列變化,你是否會聯想到背后的銷售數據波動?三年前在零售行 ...
2025-05-23在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25