亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

如何在python中用os模塊實現(xiàn)批量移動文件

 更新時間:2022年05月20日 10:21:40   作者:Python熱愛者  
在工作中難免會遇到需要批量整理文件的情況,當需要從一堆文件中將部分文件批量地轉(zhuǎn)移時,如果手工一一轉(zhuǎn)移難免浪費時間,這篇文章主要給大家介紹了關(guān)于如何在python中用os模塊實現(xiàn)批量移動文件的相關(guān)資料,需要的朋友可以參考下

本文介紹一下利用python批量把一個文件夾(及其子文件夾)下面的特定類型的文件移動到另一個文件夾下

通過python操作系統(tǒng)目錄及其文件,需要用到os包,本次具體用到如下方法

  • os.walk(), 這個方法可以遍歷一個文件夾及其子文件(子子文件夾等)
  • os.rename(),這個方法用于命名文件或目錄(因為是操作一個文件的絕對路徑,所以其實相當于對文件進行剪切操作)

另外也可以借助 shutil庫對文件進行移動或復(fù)制操作

下面是示例代碼

def run_main(source_dir, target_dir):
    num = 0
    for root, dirs, files in os.walk(source_dir, topdown=False):
        # root 表示當前正在訪問的文件夾路徑
        # dirs 表示該文件夾下的子目錄名list
        # files 表示該文件夾下的文件list
        for name in files:
            # print(os.path.join(root, name))
            # print(type(os.path.join(root, name)))
            file = os.path.join(root, name)  # 拼接文件的完整路徑(注意我們對一個文件或文件夾操作,一定要使用絕對路徑)
            print(file)
            if file.split(".")[-1] in ["xls", "xlsx", "csv"]:  # 使用split判斷獲得的文件路徑是不是以csv結(jié)尾
                # print(file)
                tar_file = file.split(".")[-2]+str(num)+"."+file.split(".")[-1] # 為了避免有重名文件,給原文件名后加一個遞增序號num形成新的文件名
                # print(target_dir+tar_file.split("\\")[-1])
                if os.path.isfile(target_dir + tar_file.split("\\")[-1]): # 判斷目標文件夾是否已存在該文件
                    print("已經(jīng)存在該文件")
                else:
                    print("正在移動第{}個文件:{}".format(num+1, tar_file.split("\\")[-1]))
                    os.rename(file, target_dir + tar_file.split("\\")[-1])
                num += 1
if __name__ == '__main__':
    run_main("D:/source/", "D:/target/")

關(guān)于如何復(fù)制文件,還可以借助shutil

將文件內(nèi)容拷貝到另一個文件中

import shutil
shutil.copyfileobj(open('old.xml','r'), open('new.xml','w'))
shutil.copyfile(src, dst)

拷貝文件

shutil.copyfile('f1.log','f2.log')#目標文件無需存在
shutil.copymode(src, dst)

僅拷貝權(quán)限。內(nèi)容、組、用戶均不變

shutil.copymode('f1.log','f2.log')#目標文件必須存在
shutil.copystat(src, dst)

僅拷貝狀態(tài)的信息,包括:mode bits, atime, mtime, flags

shutil.copystat('f1.log','f2.log')#目標文件必須存在
shutil.copy(src, dst)

拷貝文件和權(quán)限

import shutil23shutil.copy('f1.log','f2.log')
shutil.copy2(src, dst)

拷貝文件和狀態(tài)信息

import shutil23shutil.copy2('f1.log','f2.log')
shutil.ignore_patterns(*patterns) #基本用不到
shutil.copytree(src, dst, symlinks=False, ignore=None)

遞歸的去拷貝文件夾

import shutil
shutil.copytree('folder1','folder2', ignore=shutil.ignore_patterns('*.pyc','tmp*'))
#目標目錄不能存在,注意對folder2目錄父級目錄要有可寫權(quán)限,ignore的意思是排除
shutil.rmtree(path[, ignore_errors[, onerror]]) 

遞歸的去刪除文件

import shutil
shutil.rmtree('folder1')
shutil.move(src, dst)

遞歸的去移動文件,它類似mv命令,其實就是重命名。

import shutil
shutil.move('folder1','folder3')
shutil.make_archive(base_name, format,...)

創(chuàng)建壓縮包并返回文件路徑,例如:zip、tar

base_name: 壓縮包的文件名,也可以是壓縮包的路徑。只是文件名時,則保存至當前目錄,否則保存至指定路徑,

如:/tmp/data_bak =>保存至/tmp/

format: 壓縮包種類,“zip”, “tar”, “bztar”,“gztar”

root_dir: 要壓縮的文件夾路徑(默認當前目錄)

owner: 用戶,默認當前用戶

group: 組,默認當前組

logger: 用于記錄日志,通常是logging.Logger對象

#將 /data 下的文件打包放置當前程序目錄
import shutil
ret = shutil.make_archive("data_bak", 'gztar', root_dir='/data')
#將 /data下的文件打包放置 /tmp/目錄
import shutil
ret = shutil.make_archive("/tmp/data_bak", 'gztar', root_dir='/data')

總結(jié)

到此這篇關(guān)于如何在python中用os模塊實現(xiàn)批量移動文件的文章就介紹到這了,更多相關(guān)python用os模塊批量移動文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Django ORM判斷查詢結(jié)果是否為空,判斷django中的orm為空實例

    Django ORM判斷查詢結(jié)果是否為空,判斷django中的orm為空實例

    這篇文章主要介紹了Django ORM判斷查詢結(jié)果是否為空,判斷django中的orm為空實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Python特殊屬性property原理及使用方法解析

    Python特殊屬性property原理及使用方法解析

    這篇文章主要介紹了Python特殊屬性property原理及使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • 如何獲取Python簡單for循環(huán)索引

    如何獲取Python簡單for循環(huán)索引

    這篇文章主要介紹了如何獲取Python簡單for循環(huán)索引,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • 離線部署Python環(huán)境的詳細過程

    離線部署Python環(huán)境的詳細過程

    本文主要介紹了離線部署Python環(huán)境的全過程,包括前置工作、部署Python、測試Python、配置環(huán)境和驗證Python五個步驟,為讀者提供了詳細的操作指南,希望能對需要離線部署Python環(huán)境的讀者提供幫助
    2024-10-10
  • Python統(tǒng)計列表中的重復(fù)項出現(xiàn)的次數(shù)的方法

    Python統(tǒng)計列表中的重復(fù)項出現(xiàn)的次數(shù)的方法

    這篇文章主要介紹了Python統(tǒng)計列表中的重復(fù)項出現(xiàn)的次數(shù)的方法,需要的朋友可以參考下
    2014-08-08
  • 詳解OpenCV中簡單的鼠標事件處理

    詳解OpenCV中簡單的鼠標事件處理

    談及鼠標事件,就是在觸發(fā)鼠標按鈕后程序所做出相應(yīng)的反應(yīng),但是不影響程序的整個線程。本文將主要介紹OpenCV中的簡單鼠標事件處理,感興趣的可以學習一下
    2022-01-01
  • python爬取各類文檔方法歸類匯總

    python爬取各類文檔方法歸類匯總

    網(wǎng)絡(luò)爬蟲不僅需要能夠抓取HTML中的敏感信息,也需要有抓取其他類型文檔的能力這篇文章主要為大家匯總了python爬取各類文檔方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • 人工智能—Python實現(xiàn)線性回歸

    人工智能—Python實現(xiàn)線性回歸

    這篇文章主要介紹了人工智能—Python實現(xiàn)線性回歸,人工智能分為類型、數(shù)據(jù)集、效果評估、等,線性回歸根據(jù)隨機初始化的?w?x?b?和?y?來計算?loss等步驟實現(xiàn),下面來看看文章的具體實現(xiàn)吧
    2022-01-01
  • 基于Pytorch SSD模型分析

    基于Pytorch SSD模型分析

    今天小編就為大家分享一篇基于Pytorch SSD模型分析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 詳解Python中深淺拷貝的使用及注意事項

    詳解Python中深淺拷貝的使用及注意事項

    Python中的深淺拷貝是經(jīng)常被使用的概念,對于初學者來說可能會比較難以理解,本文將詳細闡述Python深淺拷貝的概念、使用場景、注意事項以及如何實現(xiàn)深淺拷貝
    2023-04-04

最新評論