溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python中存取文件的4種不同操作

發(fā)布時間:2020-09-01 18:31:20 來源:腳本之家 閱讀:146 作者:小詹學Python 欄目:開發(fā)技術(shù)

前言:

最近開始學習tensorflow框架,選修課讓任選一種框架實現(xiàn)mnist手寫數(shù)字的識別分類。小詹也就隨著大流選擇了 tf 框架,跟著教程邊學邊做,小詹用了不同的神經(jīng)網(wǎng)絡(luò)實現(xiàn)了識別分類,其中有一個步驟是將訓練過程得到的模型進行保存,在之后的測試中加載并使用該模型。想到這種先保存再加載調(diào)用的過程,之前很多地方都遇到過呀,最簡單常用的就是python中文件的存取哇!于是乎,小詹夜觀星象,就著手整理記錄各種文件存取的騷操作,具體如下。

(PS:雖然我知道技術(shù)文章太長,耐心看完的人很少,曝光率和點贊率會下降,更不會有什么收益,但是還是想記錄下自己學習過程中的一些筆記,以后自己或者別人查起來方便些?。?/p>

方法預覽

●Python內(nèi)置方法

●numpy模塊方法

●os模塊方法

●csv模塊方法

Python內(nèi)置方法

在不需要借助任何外界庫的前提下,python內(nèi)置方法其實也可以完成我們需要的文件存取任務(wù),這里主要介紹幾種python內(nèi)置方法的使用方式,最后再給出一個實際案例展示:

1、open()方法

file object = open(file_name [, access_mode][, buffering])

該方法意義在于按照指定模式打開文件,其中,各個參數(shù)的含義如下:

file_name:file_name變量是一個包含了你要訪問的文件名稱的字符串值。

access_mode:access_mode決定了打開文件的模式:只讀,寫入,追加等。所有可取值見如下的完全列表。這個參數(shù)是非強制的,默認文件訪問模式為只讀(r)。常用文件訪問模式見下圖(來源于網(wǎng)絡(luò))

Python中存取文件的4種不同操作

buffering:  如果buffering的值被設(shè)為0,就不會有寄存。如果buffering的值取1,訪問文件時會寄存行。如果將buffering的值設(shè)為大于1的整數(shù),表明了這就是的寄存區(qū)的緩沖大小。如果取負值,寄存區(qū)的緩沖大小則為系統(tǒng)默認。

2、close()方法

fileObject.close()

File 對象的 close()方法刷新緩沖區(qū)里任何還沒寫入的信息,并關(guān)閉該文件,這之后便不能再進行寫入。當一個文件對象的引用被重新指定給另一個文件時,Python 會關(guān)閉之前的文件。用 close()方法關(guān)閉文件是一個很好的習慣。

3、write ()方法

fileObject.write(string)

write()方法可將任何字符串寫入一個打開的文件。需要重點注意的是,Python字符串可以是二進制數(shù)據(jù),而不是僅僅是文字。write()方法不會在字符串的結(jié)尾添加換行符('\n');被傳遞的參數(shù)是要寫入到已打開文件的內(nèi)容。

4、read () 方法 

fileObject.read([count])read()

方法從一個打開的文件中讀取一個字符串。需要重點注意的是,Python字符串可以是二進制數(shù)據(jù),而不是僅僅是文字。被傳遞的參數(shù)是要從已打開文件中讀取的字節(jié)計數(shù)。該方法從文件的開頭開始讀入,如果沒有傳入count,它會嘗試盡可能多地讀取更多的內(nèi)容,很可能是直到文件的末尾。

5、舉例分析

一般情況,建議小伙伴們使用with ...as...寫法,這種會在執(zhí)行完代碼塊后自動close,既可以簡化程序,又可以避免自己粗心或者其他原因造成的不必要錯誤,下面給出一個實際案例。

#先用open方法打開(不存在則創(chuàng)建)一個文件,
#write方法寫入內(nèi)容,這里with寫法不用手動close
#注意這里是模式‘a(chǎn)',意味著寫入內(nèi)容不覆蓋已有內(nèi)容
with open('test.txt','a') as file_test:
 file_test.write('小詹是個美男子!\n')
 file_test.write('請關(guān)注公眾號【小詹學python】!\n') 
#注意利用read方法讀取內(nèi)容,模式要設(shè)置為可讀模式
#read()方法不帶參數(shù),表示默認讀取最長內(nèi)容
with open('test.txt','r') as file_test:
 str = file_test.read()
 print(str)

輸出結(jié)果會在目錄下多出一個test.txt文件,并讀取后輸出所有內(nèi)容,下圖為執(zhí)行了三次的結(jié)果,說明模式‘a(chǎn)'不會覆蓋已有內(nèi)容(重要的事情說三遍?。?/p>

Python中存取文件的4種不同操作

numpy模塊方法

這里主要介紹numpy模塊中的兩個常用方法,用于保存讀取數(shù)據(jù)。

np.loadtxt(filename, dtype=int, delimiter=' ')
np.savetxt(filename, a, fmt="%d", delimiter=",")

其中,filename為要保存或讀取的文件名,a為存取的內(nèi)容,delimiter為分隔符號。這個使用很簡單,代碼如下:

import numpy as np

a=np.arange(0,10,0.5).reshape(4,-1)
#改為保存為整數(shù),以逗號分隔
np.savetxt("a.txt",a,fmt="%d",delimiter=",")
#load時也要指定為逗號分隔
b = np.loadtxt("a.txt",delimiter=",")
print('b=\n',b)

其運行結(jié)果,創(chuàng)建了一個名為'a.txt‘ 的文件,保存了數(shù)組,并print打印出來讀取結(jié)果,如下圖:

Python中存取文件的4種不同操作

os模塊方法

python中的os模塊很強大,提供了許多文件處理操作的方法。以下列舉出常用的幾種方法。

1、os.open()

os.open(file, flags[, mode]);

其中,參數(shù)含義為:

file -- 要打開的文件

flags -- 該參數(shù)可以是以下選項,多個使用 "|" 隔開:

  • os.O_RDONLY: 以只讀的方式打開
  • os.O_WRONLY: 以只寫的方式打開
  • os.O_RDWR : 以讀寫的方式打開
  • os.O_NONBLOCK: 打開時不阻塞
  • os.O_APPEND: 以追加的方式打開
  • os.O_CREAT: 創(chuàng)建并打開一個新文件
  • os.O_TRUNC: 打開一個文件并截斷它的長度為零(必須有寫權(quán)限)
  • os.O_EXCL: 如果指定的文件存在,返回錯誤
  • os.O_SHLOCK: 自動獲取共享鎖
  • os.O_EXLOCK: 自動獲取獨立鎖
  • os.O_DIRECT: 消除或減少緩存效果
  • os.O_FSYNC : 同步寫入
  • os.O_NOFOLLOW: 不追蹤軟鏈接

2、os.rename(current_name,new_name)方法用于更改文件名稱

3、os.remove(filename)方法用于刪除指定文件

4、os.mkdir('newdir')方法用于創(chuàng)建單層目錄,如果該目錄已存在會拋出異常

5、os.chdir('newdir')方法用于改變當前工作目錄

6、os.getcwd()方法獲取當前工作目錄

7、os.write(fd,str)向指定文件寫入內(nèi)容,注意str要轉(zhuǎn)換成byte

這里注意針對內(nèi)容的寫入舉例,注意str要轉(zhuǎn)換成byte,否則會報錯(a bytes-like object is required, not ‘str')!

import os
# # 打開文件
fd = os.open("f1.txt",os.O_RDWR|os.O_CREAT)
# # 寫入字符串
line = "this is xiaozhan"
b = str.encode(line)
os.write(fd,b)
# #直接寫str報錯:a bytes-like object is required, not ‘str'
os.close(fd)
#以可讀模式打開
fd = os.open("f1.txt",os.O_RDWR)
ret = os.read(fd,16)
print(ret)
os.close(fd)
print('finish close')
# os.remove('f1.txt')

運行結(jié)果如下:

Python中存取文件的4種不同操作

csv模塊方法

和前幾種方法一樣,主要是讀取和寫入兩個部分。主要依靠csv.reader(),csv.writer()和writerow()方法。和前邊幾種大同小異,這里直接代碼中講解基礎(chǔ)的使用方式。

import csv

with open('l.csv', 'w',newline='') as csvfile:
 #csv.writer()方法創(chuàng)建
 eWriter = csv.writer(csvfile)
 #用writerow()方法逐行寫入
 eWriter.writerow(['ID', '名字', '粉絲數(shù)量'])
 eWriter.writerow(['xiaoxiaozhantongxue','小詹學python',15000])
 eWriter.writerow(['xiaoxiaozhantongxue','小詹學python',15000])
 eWriter.writerow(['xiaoxiaozhantongxue','小詹學python',15000])

#打開文件,用with打開可以不用去特意關(guān)閉file了,python3不支持file()打開文件,只能用open()
with open('l.csv','r') as csvfile:
 #讀取csv文件,返回的是迭代類型
 read = csv.reader(csvfile)
 for i in read:
  print(i)

運行結(jié)果如下圖:

Python中存取文件的4種不同操作

以上就是本次整理的內(nèi)容了,方便自己查閱也希望對各位讀者有一丟丟用噢!文章太長,耐心看到這的,我得給你點個贊,送你一個么么噠。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI