首頁  >  文章  >  後端開發  >  Python中的檔案操作

Python中的檔案操作

高洛峰
高洛峰原創
2017-02-27 17:02:161285瀏覽

1.能呼叫方法的一定是對象,例如數值、字串、列表、元組、字典,甚至文件也是對象,Python中一切皆為對象。

 str1 = 'hello'
 str2 = 'world'
 str3 = ' '.join([str1,str2])
 print(str3)

2.三種基本的檔案操作模式:r(only-read)、w(only-write)、a(append)

對文件進行操作的流程:

     第一,建立檔案物件。

     第二,呼叫檔案方法操作。

     第三,不要忘了關閉檔案。 (檔案不關閉的情況下,內容會放在緩存,雖然Python會在最後自動把內容讀到磁碟,但為了以防萬一,要養成關閉檔案的習慣)

檔案file1

一张褪色的照片,
好像带给我一点点怀念。
巷尾老爷爷卖的热汤面,
味道弥漫过旧旧的后院;
流浪猫睡熟在摇晃秋千,
夕阳照了一遍他咪着眼;
那张同桌寄的明信片,
安静的躺在课桌的里面。

(1)r模式

在唯讀模式下寫入內容會報錯。

 f = open('file1','r')
 f_read = f.read()   #read是逐字符地读取,read可以指定参数,设定需要读取多少字符,无论一个英文字母还是一个汉字都是一个字符。
 print(f_read)
 f.close()

 f = open('file1','r')
 f_read = f.readline() #readline只能读取第一行代码,原理是读取到第一个换行符就停止。
 print(f_read)
 f.close()

#
 f = open('file1','r')
 f_read = f.readlines() #readlines会把内容以列表的形式输出。
 print(f_read)
 f.close()

 f = open('file1','r')
 for line in f.readlines() #使用for循环可以把内容按字符串输出。
   print(line) #输出一行内容输出一个空行,一行内容一行空格... 因为文件中每行内容后面都有一个换行符,而且print()语句本身就可以换行,如果不想输出空行,就需要使用下面的语句:print(line.strip())
 f.close()

(2)w模式

在進行操作前,檔案中所有內容會被清空。例如在file1寫入'hello world',程式執行後file1就只剩下一句'hello world'

 f = open('file1','w',encoding='utf8')  #由于Python3的默认编码方式是Unicode,所以在写入文件的时候需要调用utf8,以utf8的方式保存,这时pycharm(默认编码方式是utf8)才能正确读取,当读取文件时,文件是utf8格式,pycharm也是utf8,就不需要调用了。
 f_w = f.write('hello world')
 print(f_w)  #有意思的是,这里并不打印'hello world',只打印写入多少字符
 f.close()

(3)a模式

與w模式不同的是,a模式不會把原來內容清空,而是遊標移到內容最後位置,繼續寫入新內容。例如在最後追加'hello world'

 f = open('file1','a')
 f_a = f.write('hello world')
 print(f_a) #还是会打印写入的字符数
 f.close()

#打印文件,在'流浪貓睡熟在搖晃鞦韆'後面加上'helloworld'輸出

在r模式時,我們說過用for循環和readlines()輸出文件內容,這種輸出內容的原理是:打開文件,把全部內容讀入內存,然後再打印輸入,當文件很大時,這種讀取方式就不太可靠了,甚至會讓機器崩潰。我們需要及時關閉文件,如下:

f = open('file','r')
data=f.readlines()  #注意及时关闭文件
f.close()

num = 0
for i in data:
  num += 1
  if num == 5:
    i = ''.join([i.strip(),'hello world']) #不要使用“+”进行拼接
  print(i.strip())
f.close()

對於大數據文件,要使用下面的方法:

num = 0
f.close()  #不要过早关闭文件,否则程序不能识别操作句柄f.
f = open('file','r')
for i in f:  #for内部把f变为一个迭代器,用一行取一行。
  num += 1
  if num == 5:
    i = ''.join([i.strip(),'hello world'])
  print(i.strip())
f.close()

3.tell與seek

     tell:查詢檔案中遊標位置

     seek:遊標定位

f = open('file','r')
print(f.tell())  #光标默认在起始位置
f.seek(10)    #把光标定位到第10个字符之后
print(f.tell())  #输出10
f.close()
----------------------
f = open('file','w')
print(f.tell())  #先清空内容,光标回到0位置
f.seek(10)    
print(f.tell())
f.close()
----------------------
f = open('file','a')
print(f.tell())  #光标默认在最后位置
f.write('你好 世界')
print(f.tell())  #光标向后9个字符,仍在最后位置
f.close()

#4.flush 同步將資料從快取轉移到磁碟

範例,實作進度條功能

import sys,time  #导入sys和time模块
for i in range(40):
  sys.stdout.write('*')
  sys.stdout.flush()  #flush的作用相当于照相,拍一张冲洗一张
  time.sleep(0.2)
下面代码也能够实现相同的功能
import time 
for i in range(40):
  print('*',end='',flush=True) #print中的flush参数
  time.sleep(0.2)

5.truncate 截斷

不能是r模式下執行,

w模式下,已經清空所有數據,使用truncate沒有任何意義,

a模式下,截斷指定位置後的內容。

 f = open('file','a')
 f.truncate(6) #只显示6个字节的内容(6个英文字符或三个汉字),后面的内容被清空。

6.遊標位置總結

一個漢字兩個位元組,涉及遊標位置的方法有4個:read、tell、 seek、truncate。

#--------------------------光标总结head-----------------------------------
f = open('file','r')
print(f.read(6)) #6个字符
print(f.tell())  #位置12字节,一个汉字两个字节
f.close()

f = open('file','r')
f.seek(6)      #6个字节
print(f.tell())
f.close()

f = open('file','a')
print(f.tell())  #光标默认在最后位置
f.write('你好 世界')
print(f.tell())  #光标向后9个字节,一个汉字两个字节,仍在最后位置 182-->191
f.close()

f = open('file','a',encoding='utf-8')
print(f.truncate(6)) #由于需要光标定位位置,所以也是字节。只显示6个字节的内容(6个英文字母或三个汉字,一个汉字两个字节),后面的内容被清空。
f.close()
#-----------------------------光标总结end---------------------------------

7.另外3種模式:r+、w+、a+

      r+:讀取和寫入模式,遊標預設在起始位置,當需要寫入的時候,遊標自動移到最後

     w+:寫入模式,先清空原內容,再寫入,也能夠讀取

     a+:追加讀模式,遊標預設在最後位置,直接寫入,也能夠讀取。

f = open('file','a')
print(f.tell())  #末尾207位置
f.close()

f = open('file','r+')
print(f.tell())  #0位置
print(f.readline()) #读取第一行
f.write('羊小羚')   #光标移到末尾207位置并写入
print(f.tell())  #213位置
f.seek(0)     #光标移到0位置
print(f.readline())  #读取第一行
f.close()

8.修改檔案內容

#想法:由於資料儲存機制的關係,我們只能把檔案1中的內容讀取出來,經過修改後,放到文件2。

f2 = open('file2','w',encoding='utf8')  #写入的时候必须加utf8
f1 = open('file','r')
num = 0
for line in f1: #迭代器
  num += 1
  if num == 5:
    line = ''.join([line.strip(),'羊小羚\n'])  #里面就是对字符串进行操作了
  f2.write(line)
f1.close()
f2.close()

9.with語句

#可以同時對多個檔案同時操作,當with程式碼區塊執行完畢時,會自動關閉文件釋放記憶體資源,不用刻意加f.close() ,我們透過下面的範例體會with的用法和好處。


用with語句重寫8中的程式碼

#

num = 0
with open('file','r') as f1,open('file2','w',encoding='utf8') as f2:
  for line in f1:
    num += 1
    if num == 5:
      line = ''.join([line.strip(),'羊小羚'])
    f2.write(line)

10.總結

以上就是這篇文章的全部內容,希望對大家能有所幫助。如果有疑問可以留言交流


更多Python中的檔案操作相關文章請關注PHP中文網!

#########
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn