python下的所有文件_python批量复制文件夹下所有文件大小
python復制文件夾下所有文件
Python---進階---文件操作---獲取文件夾下所有文件的數(shù)量和大小
一、####編寫一個程序,統(tǒng)計當前目錄下每個文件類型的文件數(shù)
####思路:
- 打開當前的文件夾
- 獲取到當前文件夾下面所有的文件
- 處理我們當前的文件夾下面可能有文件夾的情況(也打印出來)
- 做出統(tǒng)計
import os
#獲取到當前文件夾下面所有的文件
all_files = os.listdir(os.curdir) #os.curdir 表示當前目錄 curdir:currentdirectory
type_dict = dict()
for each_file in all_files:
# 如果說我們的each_file是文件夾
if os.path.isdir(each_file):
type_dict.setdefault("文件夾", 0)
type_dict["文件夾"] += 1
else:
# 如果不是文件夾,而是文件,統(tǒng)計我們的文件
ext = os.path.splitext(each_file)[1] #獲取到文件的后綴
type_dict.setdefault(ext, 0)
type_dict[ext] += 1
for each_type in type_dict:
print("該文件夾下面有類型為{}的文件{}個".format(each_type, type_dict[each_type]))
二、
# 編寫一個程序,計算當前文件夾下面所有文件的大小
- 打開當前的文件夾
- 獲取到所有的文件, 和文件大小
- 保存我們獲取到的數(shù)據(jù),然后打印出來
import os
all_files = os.listdir(os.curdir)
file_dict = dict()
for each_file in all_files:
# 判斷我們的這個each_file是否是文件
if os.path.isfile(each_file):
file_size = os.path.getsize(each_file)
file_dict[each_file] = file_size
for each in file_dict.items():
print("{}大小{}".format(each[0], each[1]))
用Python批量復制文件,方法有9種
當我們復制一個文件時用復制粘貼就可以了,如果是多個文件呢?就會很麻煩了,今天給大家介紹一下用Python批量復制文件,方法有九種!希望對你有幫助
1. Shutil Copyfile()方法
該方法只有在目標可寫時才將源的內(nèi)容復制到目的地。如果您沒有寫入權(quán)限,則會引發(fā)IOError。
它通過打開輸入文件進行閱讀,忽略其文件類型。接下來,它不會對特殊文件進行任何不同的處理,也不會將它們復制為新的特殊文件。
所述的CopyFile()方法利用較低級別的功能的copyfileobj()的下方。它將文件名稱作為參數(shù),打開它們并將文件句柄傳遞給copyfileobj()。該方法中有一個可選的第三個參數(shù),您可以使用它來指定緩沖區(qū)長度。然后它將打開文件以讀取指定緩沖區(qū)大小的塊。但是,默認行為是一次性讀取整個文件。
以下是有關(guān)copyfile()方法的要點。
它將源的內(nèi)容復制到名為目標的文件。如果目的地不可寫,則復制操作將導致IOError異常。如果源文件和目標文件都相同,它將返回SameFileError。但是,如果目的地以不同的名稱預先存在,則副本將覆蓋其內(nèi)容。如果目的地是目錄,則意味著此方法將不會復制到目錄,將會發(fā)生錯誤13。它不支持復制文件,如字符或塊設(shè)備和管道。
2. Shutil Copy()方法
copy()方法的功能類似于"CP"在Unix命令。這意味著如果目標是一個文件夾,那么它將在其中創(chuàng)建一個與源文件相同的名稱(basename)的新文件。此外,該方法將復制其內(nèi)容后將目標文件的權(quán)限與源進行同步。 如果要復制相同的文件,它也會拋出SameFileError。
3. Shutil Copyfileobj()方法
此方法將文件復制到目標路徑或文件對象。如果目標是文件對象,則需要在調(diào)用copyfileobj()之后明確關(guān)閉它。它假設(shè)一個可選參數(shù)(緩沖區(qū)大小),您可以使用它來提供緩沖區(qū)長度。這是在復制過程中保存在內(nèi)存中的字節(jié)數(shù)。系統(tǒng)使用的默認大小為16KB。
4. Shutil Copy2()方法
但是,copy2()方法的功能類似于copy()。但是,在復制數(shù)據(jù)的同時,也可以在元數(shù)據(jù)中添加訪問和修改時間。復制同一個文件會導致SameFileError。
對于好奇 – Copymode()與Copystat()之間的區(qū)別。
5. Os Popen()方法
該方法創(chuàng)建一個指向或來自該命令的管道。它返回一個連接到管道的打開的文件對象。您可以根據(jù)文件打開模式(即'r'(默認)或'w')使用它進行讀取或?qū)懭搿?/p>
模式 –它可以是'r'(默認)或'w'。fsize –如果其值為0,則不會發(fā)生緩沖。如果設(shè)置為1,則在訪問文件時將進行行緩沖。如果您提供的值大于1,則緩沖將以指定的緩沖區(qū)大小進行。但是,對于負值,系統(tǒng)將采用默認緩沖區(qū)大小。
對于Windows操作系統(tǒng)。
對于Linux操作系統(tǒng)。
6. Os System()方法
它是運行任何系統(tǒng)命令的最常見方式。使用system()方法,可以在subshell中調(diào)用任何命令。在內(nèi)部,這種方法會調(diào)用標準的C庫函數(shù)。
此方法返回命令的退出狀態(tài)。
對于Windows操作系統(tǒng)。
對于Linux操作系統(tǒng)。
7.以Async方式使用線程庫的Python文件復制
如果要以異步方式復制文件,請使用以下方法。在這里,我們使用Python的線程模塊在后臺運行復制操作。
使用此方法時,請確保采用鎖定以避免死鎖。如果您的應用程序正在使用多個線程讀取/寫入文件,您可能會面對它。
8.使用子進程的Call()方法在Python中復制一個文件
子進程模塊提供了一個簡單的界面來處理子進程。它使我們能夠啟動子進程,附加到其輸入/輸出/錯誤管道,并檢索返回值。
子流程模塊旨在替代傳統(tǒng)模塊和功能,如os.system,os.spawn *,os.popen *,popen2。*。
它公開一個call()方法來調(diào)用系統(tǒng)命令來執(zhí)行用戶任務(wù)。
9.使用子進程的Check_output()方法在Python中復制文件
使用子進程的check_output()方法,可以運行外部命令或程序并捕獲其輸出。它還支持管道。
學會了嗎?
以上就是本次給大家分享的關(guān)于java的全部知識點內(nèi)容總結(jié),大家還可以在下方相關(guān)文章里找到相關(guān)文章進一步學習,感謝大家的閱讀和支持。
總結(jié)
以上是生活随笔為你收集整理的python下的所有文件_python批量复制文件夹下所有文件大小的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: bagging和时间序列预测_时间序列的
- 下一篇: 我国首台紧凑型加速器质谱仪研制成功,相关