黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

一篇文章搞定Python操作文件與目錄

系統(tǒng) 2127 0

前言

文件和目錄操作是很常見(jiàn)的功能,這里做個(gè)簡(jiǎn)單的總結(jié),包括注意事項(xiàng)和實(shí)際的實(shí)現(xiàn)代碼,基本日常開(kāi)發(fā)都?jí)蛴昧?

目錄操作

判斷目錄或是文件是否存在

            
os.path.exists(path)
          

判斷是否是文件或是目錄

            
# 如果文件或是目錄不存在也會(huì)返回False
os.path.isfile(path)
os.path.isdir(path)
          

創(chuàng)建/刪除目錄

            
os.mkdir(path)
os.rmdir(path)
          

得到當(dāng)前的目錄名稱

            
os.path.split(dir_path)[1]
          

這個(gè)方法既簡(jiǎn)單又實(shí)用,比如我們輸入一個(gè)目錄路徑:

            
os.path.split('/usr/projects/project1')[1]
# 輸出
project1

# 實(shí)際上,上面的代碼是分了2步走:
# 第1步:利用os.path.split方法分割路徑
os.path.split('/usr/projects/project1')
# 輸出
('/usr/projects', 'project1')
# 然后第2步取出第2個(gè)結(jié)果,也就是當(dāng)前的目錄名字
          

循環(huán)遍歷目錄

循環(huán)遍歷目錄有2種方式,一種是常規(guī)的遞歸方法,類似下面這樣:

            
def list_file(path):
 for file in os.listdir(path):
  if os.path.isdir(os.path.join(path, file)):
   list_file(os.path.join(path, file))
  print(file)
          

還有一種更好的方式就是用os.walk方法,類似下面這樣:

            
def list_file_by_walk(dir_path):
 for home, dirs, files in os.walk(dir_path):
  print(home)
  print(dirs)
  # files中是文件列表
  for file_name in files:
   print(file_name)
          

os.walk方法的幾個(gè)參數(shù)簡(jiǎn)單介紹一下:

  • home:這個(gè)是當(dāng)前遍歷的目錄,比如說(shuō)是 /usr/projects/
  • dirs:是這個(gè)目錄(home目錄)下面的所有文件夾(也就是子目錄)
  • files:是這個(gè)目錄(home目錄)下所有的文件

所以從上面的參數(shù)中可以看出,os.walk方法會(huì)逐一地遍歷初始目錄下面的所有目錄和文件

常見(jiàn)的文件操作

跟上面得到目錄名類似的是得到文件的后綴

            
os.path.splitext(file_path)
          

這個(gè)方法如果輸入的是文件的路徑,比如:

            
a = '/usr/projects/project1/test.txt'
os.path.splitext(a)
# 輸出
('/usr/projects/project1/test', '.txt')
# 所以跟上面類似,我們可以直接拿到文件的后綴
os.path.splitext(a)[1]
          

文件的全路徑

            
# 需要文件的目錄路徑和文件名
os.path.join(dir_name, file_name)
          

這個(gè)方法也很有用,因?yàn)槲覀冊(cè)诖蜷_(kāi)一個(gè)文件的時(shí)候都需要知道文件的路徑

比如在上面循環(huán)遍歷目錄的例子中,我們可以這樣打開(kāi)編輯文件:

            
def list_file_by_walk(dir_path):
  for home, dirs, files in os.walk(dir_path):
    print(home)
    print(dirs)
    # files中是文件列表
    for file_name in files:
      # 這個(gè)file_name只是一個(gè)文件名
      print(file_name)
      # 如果我們需要打開(kāi)文件進(jìn)行編輯讀寫操作,那就需要文件的路徑
      # 用os.path.join方法就可以快速得到文件路徑
      file_path = os.path.join(home, file_name)
          

需要注意的是,不要直接用字符串相加的方式來(lái)拼接,這樣子會(huì)有兼容問(wèn)題,比如windows上可能路徑就是錯(cuò)的了

讀寫文件

打開(kāi)文件

            
with open(file, 'r') as f:
  for line in f.readlines():
    print line
          

大家只要記住上面打開(kāi)文件的格式就行了,也就是這句:

            
with open(file_path, 打開(kāi)的模式) as f
# 我們就拿到了文件對(duì)象f,可以對(duì)文件進(jìn)行操作了,比如讀寫等
          

原因是文件讀寫是IO操作,需要及時(shí)關(guān)閉打開(kāi)的文件,上述with open() as f的方式會(huì)自動(dòng)幫你關(guān)閉文件的,免得自己忘記關(guān)

文件的打開(kāi)模式

文件的打開(kāi)模式有很多種,比如只讀、只寫、追加模式等等,具體可以見(jiàn)下圖:

一篇文章搞定Python操作文件與目錄_第1張圖片
文件讀寫模式--來(lái)源于網(wǎng)絡(luò)

模式有這么多,掌握常見(jiàn)的幾種就可以了,其他的等用到了再去了解。需要注意以下幾點(diǎn):

創(chuàng)建文件,只需要打開(kāi)一個(gè)文件即可:

            
# 只要這樣一句就創(chuàng)建了一個(gè)新文件,也就是打開(kāi)以后關(guān)閉文件
with open(new_file, 'w') as f:
          

需要特別注意的是,以w只寫模式打開(kāi)一個(gè)文件后會(huì)把原文件的內(nèi)容清除!所以如果在遍歷文件的時(shí)候,你想同時(shí)修改文件就不能簡(jiǎn)單的以w只寫模式打開(kāi)了。

在遍歷文件的時(shí)候想同時(shí)修改文件怎么辦呢?注意這里說(shuō)的是修改,比如修改某一行。

修改文件的某一部分

這里舉例在遍歷文件的時(shí)候想修改文件,比如以上面遍歷目錄文件的例子:

            
def list_file_by_walk(dir_path):
  for home, dirs, files in os.walk(dir_path):
    print(home)
    print(dirs)
    # files中是文件列表
    for file_name in files:
      # 這個(gè)file_name只是一個(gè)文件名
      print(file_name)
      # 如果我們需要打開(kāi)文件進(jìn)行編輯讀寫操作,那就需要文件的路徑
      # 用os.path.join方法就可以快速得到文件路徑
      file_path = os.path.join(home, file_name)
      
      # 這個(gè)時(shí)候我想修改這個(gè)文件的內(nèi)容,要怎么做呢?
          

需要注意的是,讀寫模式需要管理文件指針,比較麻煩,寫讀模式,則會(huì)把原先的內(nèi)容都清除,所以都不適合

一種思路是我先以只讀模式打開(kāi),然后遍歷文件的內(nèi)容保存起來(lái),比如:

            
with open(file, 'r') as f:
  for line in f.readlines():
    print line
    # 這里就可以把文件的內(nèi)容一行行保存起來(lái)
    # 找到需要修改的行,修改以后保存
          

保存以后再以只讀模式打開(kāi)文件,寫入即可。

另一種思路是我打開(kāi)原文件的同時(shí),再打開(kāi)另一個(gè)臨時(shí)文件用于寫入,比如這樣:

            
with open(file, 'r') as f, open(cache_file_path, 'w') as w:
  for line in f.readlines():
    # 中間可以對(duì)f文件中的內(nèi)容進(jìn)行過(guò)濾或是修改
    w.write(line)

# 完了以后需要?jiǎng)h除原文件,然后把臨時(shí)文件的名字修改成原來(lái)文件的名字即可
          

這里就順道引出了,刪除和重命名文件的方法

            
os.remove(file)
os.rename(cache_file_path, file)
          

總結(jié)

以上就是Python文件和目錄操作的常用知識(shí)點(diǎn)和方法總結(jié),建議大家收藏起來(lái),以后方便隨時(shí)查看。

好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論