。os.walk對於遍歷子目錄極其方便。
ps: 2014-12-12
5年後的今天,因為要寫乙個指令碼,列出5000多個分散的dicom的資訊,然後按每4gb一批打包到iso檔案中。又找到我上面的這篇文章。現在看當時這文章一是沒突出題目,主要介紹了os.walk的用法,二是細節沒說清楚。
這裡再補充幾點:
os.rename的確很快,但它有兩點要注意:
1. 目標資料夾不能夠已經存在,否則會報錯。
2. 目標資料夾的父目錄需要全部存在,否則會報錯,舉例:
要把d:\aa\bb\cc.txt移動到d:\ee\dd\cc.txt,那麼需要已經存在d:\ee\dd目錄,不存在就需要建立,
這裡推薦用os.mkdirs來遞迴建立目錄,很方便。
3. 它只是同盤移動快,不同盤還是用複製。好在現在我分割槽一般就分個c和d,多大的硬碟都這樣。
零拷貝 高效地傳輸檔案
基於使用者緩衝區傳輸檔案時,過多的記憶體拷貝與上下文切換次數會降低效能。零拷貝技術在核心中完成記憶體拷貝,天然降低了記憶體拷貝次數。它通過一次系統呼叫合併了磁碟讀取與網路傳送兩個操作,降低了上下文切換次數。尤其是,由於拷貝在核心中完成,它可以最大化使用 socket 緩衝區的可用空間,從而提高了一次...
Python 程式如何高效地除錯?
python在debug方面的支援還是不錯的,在明確 意義的情況下,通過log print和assert分析錯誤原因,配合單元測試可以很高效。然而,實際工作中大量 很可能出自他人之手,這種情況下,使用debugger就顯得更加高效了。一 在控制台下進行程式除錯 pdb如果你熟悉命令列除錯工具 例如g...
演算法14 如何高效地用堆疊模擬佇列
由於棧是先進後出,佇列是先進先出。可以採用兩個棧enstack和destack來模擬佇列的行為。佇列的基本操作包括入佇列 出佇列和佇列是否為空。入佇列時,push元素到enstack 出佇列是,從destack中執行pop操作,如果destack為空,則從enstack push元素到destack...