国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Python > 正文

python 實現目錄復制的三種小結

2024-09-09 19:02:58
字體:
來源:轉載
供稿:網友

復制目錄: 包含多層子目錄

方法: 遞歸, 深度遍歷,廣度遍歷

深度遍歷&廣度遍歷:

思路:

1.獲得源目錄子級目錄,并設置目標目錄的子級路徑

1.1在此就創建兩個棧(或者隊列),將原目錄和目標目錄分別添加到棧(或者隊列)里面,一般用append添加,加在棧的頂部,隊列的后部

1.2深度遍歷 從棧的頂部取出一個原路徑去判斷,同時用同樣的方式取出目標路徑(棧和隊列都類似于list,都可以用list實現)

廣度遍歷 從隊列的前面取出一個原路徑去判斷,同時用同樣的方式取出目標路徑

2.判斷原子級路徑是否是文件

2.1如果目標子級文件不存在 或者目標子級文件存在,但是子級大小不一致,則復制

3.判斷原子級目錄是否是目錄

3.1.遞歸 調用自己,把自己的子級目錄當作源文件,復制到目標子級目錄

3.2.深度遍歷 廣度遍歷 都將原目錄和目標目錄添加(append)到棧(隊列)的后面'''

# 深度遍歷 廣度遍歷(僅取出來的方式不一樣)# 導入模塊import os, collections def copyDir(sourcePath,targetPath):  # 傳入原目錄,和需要復制后的目標目錄  # 判斷需要復制的目錄是否存在,如果不存在就返回  if not os.path.isdir(sourcePath):    return '源目錄不存在'  # 創建兩個棧,一個用來存放原目錄路徑,另一個用來存放需要復制的目標目錄  sourceStack = collections.deque()  sourceStack.append(sourcePath)   targetStack = collections.deque()  targetStack.append(targetPath)  # 創建一個循環當棧里面位空時結束循環  while True:    if len(sourceStack) == 0:      break    # 將路徑從棧的上部取出    sourcePath = sourceStack.pop() #sourcePath = sourceStack.popleft()    # 遍歷出該目錄下的所有文件和目錄    listName = os.listdir(sourcePath)     # 將目錄路徑取出來    targetPath = targetStack.pop() #targetPath = targetStack.popleft()    # 判斷該目標目錄是否存在,如果不存在就創建    if not os.path.isdir(targetPath):      os.makedirs(targetPath)    # 遍歷目錄下所有文件組成的列表,判斷是文件,還是目錄    for name in listName:      # 拼接新的路徑      sourceAbs = os.path.join(sourcePath, name)      targetAbs = os.path.join(targetPath, name)      # 判斷是否時目錄      if os.path.isdir(sourceAbs):        # 判斷目標路徑是否存在,如果不存在就創建一個        if not os.path.exists(targetAbs):          os.makedirs(targetAbs)        # 將新的目錄添加到棧的頂部        sourceStack.append(sourceAbs)        targetStack.append(targetAbs)      # 判斷是否是文件      if os.path.isfile(sourceAbs):        # 1.如果目標子級文件不存在 或者目標子級文件存在但是該文件與原子級文件大小不一致 則需要復制        if (not os.path.exists(targetAbs)) or (os.path.exists(targetAbs) and os.path.getsize(targetAbs) != os.path.getsize(targetAbs)):          rf = open(sourceAbs, mode='rb')          wf = open(targetAbs, mode='wb')          while True:            # 一點一點讀取,防止當文件較大時候內存吃不消            content = rf.read(1024*1024*10)            if len(content) == 0:              break            wf.write(content)            # 寫入緩沖區時候手動刷新一下,可能會加快寫入            wf.flush()          # 讀寫完成關閉文件          rf.close()          wf.close()# 傳入需要復制的目錄和需要復制到的目標目錄sPath = ""tPath = ""copyDir(sPath,tPath)
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 平邑县| 厦门市| 蓬溪县| 宣威市| 郁南县| 平乐县| 全南县| 防城港市| 高安市| 新竹县| 洪湖市| 晴隆县| 尼勒克县| 林口县| 三亚市| 尼勒克县| 定安县| 咸宁市| 林州市| 光山县| 金湖县| 南丰县| 石楼县| 横山县| 永顺县| 岑巩县| 边坝县| 商丘市| 甘泉县| 内丘县| 沂南县| 高青县| 永康市| 明溪县| 南安市| 读书| 当雄县| 平遥县| 光山县| 中江县| 民乐县|