Python如何批量獲取文件夾的大小并保存
很多時候,查看一個文件夾下的每個文件大小可以輕易的做到,因為文件后面就是文件尺寸,但是如果需要查看一個文件夾下面所有的文件夾對應(yīng)的尺寸,就發(fā)現(xiàn)需要把鼠標放到對應(yīng)的文件夾上,稍等片刻才會出結(jié)果。
有時候,我們需要查看幾十個甚至于上百個文件夾,找出包含文件最多,空間占用最大的那個,就比較麻煩了。這段代碼是我以前的代碼,可以按大小排序輸出文件夾大小到txt文件,供使用的方便。
格式化當(dāng)時花了很長時間,最后發(fā)現(xiàn)使用‘YaHei.Consolas'字體可以解決,對齊后輸出結(jié)果看起來還算舒服。
上代碼:
import os
import datetime
def get_folder_size(path):
folder_size = 0
if not os.path.exists(path):
return folder_size
if os.path.isfile(path):
folder_size = os.path.getsize(path)
return folder_size
try:
if os.path.isdir(path):
with os.scandir(path) as directory_lists:
for directory_list in directory_lists:
if directory_list.is_dir():
sub_folder_size = get_folder_size(directory_list.path) # 遞歸獲取大小
folder_size += sub_folder_size
elif directory_list.is_file():
file_size = os.path.getsize(directory_list.path)
folder_size += file_size
return folder_size
except:
pass
# 以下主要是為了格式化輸出
def get_file_length(file_name):
characters = list(file_name)
ascii_length = 0
utf8_length = 0
for character in characters:
if ord(character) < 128:
ascii_length += 1
else:
utf8_length += 2
return ascii_length + utf8_length
def main(basedir):
with os.scandir(basedir) as dirs:
directory_size = []
for dir in dirs:
try:
if not dir.is_file():
dirsize = round(get_folder_size(dir.path) / 1000000) # return the file size in Mb
resformat = [dir.name, dirsize]
directory_size.append(resformat)
except:
pass
results = sorted(directory_size, key=lambda x: x[1], reverse=True) # return a list ordered by size
results = [[i[0], '文件夾大小:' + str(i[1]) + ' Mb'] for i in results]
with open(basedir + os.sep + datetime.date.today().isoformat() + '.txt', 'a+') as f:
for result in results:
# 按照50的寬度格式化輸出結(jié)果
len1 = 50 - get_file_length(result[0]) + len(result[0])
len2 = 25 - get_file_length(result[1]) + len(result[1])
f.writelines('{:<{len1}s} {:>{len2}s}\n'.format(result[0], result[1], len1=len1, len2=len2))
print('The result was successfully saved in the directory with date as file name.')
if __name__ == "__main__":
basedir = input("Please input the directory you would like to know the sizes: ")
main(basedir)
如果輸入相應(yīng)的文件夾路徑,輸出結(jié)果如下:
有時間我再簡化一下代碼,目前先這樣。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python elasticsearch從創(chuàng)建索引到寫入數(shù)據(jù)的全過程
這篇文章主要介紹了python elasticsearch從創(chuàng)建索引到寫入數(shù)據(jù)的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-08-08
教你用Django將前端的數(shù)據(jù)存入Mysql數(shù)據(jù)庫
這篇文章主要給大家介紹了關(guān)于如何用Django將前端的數(shù)據(jù)存入Mysql數(shù)據(jù)庫的相關(guān)資料,文中通過圖文以及示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Django具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2021-11-11
Pandas實現(xiàn)Excel文件讀取,增刪,打開,保存操作
Pandas?是一種基于?NumPy?的開源數(shù)據(jù)分析工具,用于處理和分析大量數(shù)據(jù)。本文將通過Pandas實現(xiàn)對Excel文件進行讀取、增刪、打開、保存等操作,需要的可以參考一下2023-04-04
python paramiko遠程服務(wù)器終端操作過程解析
這篇文章主要介紹了python paramiko遠程服務(wù)器終端操作過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-12-12
Python3調(diào)用百度AI識別圖片中的文字功能示例【測試可用】
這篇文章主要介紹了Python3調(diào)用百度AI識別圖片中的文字功能,結(jié)合實例形式分析了Python3安裝及使用百度AI接口的相關(guān)操作技巧,并附帶說明了百度官方AI平臺的注冊及接口調(diào)用操作方法,需要的朋友可以參考下2019-03-03
PyTorch模型容器與AlexNet構(gòu)建示例詳解
這篇文章主要為大家介紹了PyTorch模型容器與AlexNet構(gòu)建示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07



