欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python使用open函數(shù)對文件進(jìn)行處理詳解

 更新時間:2022年05月09日 15:41:15   作者:靜靜超愛滿滿  
今天看了open函數(shù),看到w+ r+ a+ 這種可讀可寫的操作,下面這篇文章主要給大家介紹了關(guān)于python使用open函數(shù)對文件進(jìn)行處理的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下

在python中使用open函數(shù)對文件進(jìn)行處理。

1.open()

python打開文件使用open()函數(shù),返回一個指向文件的指針。該函數(shù)常用以下三個參數(shù)。

1.1 參數(shù)1

目標(biāo)文件的路徑+名字。最好使用r"路徑"這種原始字符串寫法,防止有轉(zhuǎn)義字符影響實際路徑。

1.2 參數(shù)2

操作文件的方式mode=‘方式’。mode=可以省略。下面對操作文件的方式進(jìn)行詳細(xì)說明:

(1)r

以只讀方式打開文件。文件的指針將會放在文件的開頭。這是open默認(rèn)模式。如果文件不存在,會報錯。

(2)rb

以二進(jìn)制只讀方式打開一個文件。文件指針將會放在文件的開頭。注意這種方式不能使用encoding,不然會報錯。

同樣的內(nèi)容使用一般方式和二進(jìn)制的方式打開。

fp = open(r"E:\test.txt",'r',encoding='utf-8')
content = fp.readline()
print(content)

輸出:加油,好好干!

fp = open(r"E:\test.txt",'rb')
content = fp.readline()
print(content)

輸出:b’\xe5\x8a\xa0\xe6\xb2\xb9\xef\xbc\x8c\xe5\xa5\xbd\xe5\xa5\xbd\xe5\xb9\xb2\xef\xbc\x81’

(3)r+

以讀寫方式打開一個文件。文件指針將會放在文件的開頭。直接寫入會覆蓋文件開頭的內(nèi)容。

原始內(nèi)容:

加油,好好干!別放棄

fp = open(r"E:\test.txt",'r+',encoding='utf-8')
fp.write("開心吧")
fp.close()
fp = open(r"E:\test.txt", 'r', encoding='utf-8')
content = fp.readline()
print(content)
fp.close()

執(zhí)行后:

開心吧好好干!別放棄

(4)rb+

以二進(jìn)制讀寫方式打開一個文件。文件指針將會放在文件的開頭。

(5)w

以寫入打開一個文件。如果該文件已存在,則將其覆蓋。如果該文件不存在,則創(chuàng)建新文件。

(6)wb

以二進(jìn)制寫入方式打開一個文件。如果該文件已存在,則將其覆蓋。如果該文件不存在,則創(chuàng)建新文件。
(7)w+

以讀寫方式打開一個文件。如果該文件已存在,則將其覆蓋。如果該文件不存在,則創(chuàng)建新文件。

原始內(nèi)容:

開心吧好好干!別放棄

fp = open(r"E:\test.txt",'w+',encoding='utf-8')
fp.write("認(rèn)真一點")
fp.close()
fp = open(r"E:\test.txt", 'r', encoding='utf-8')
content = fp.readline()
print(content)
fp.close()

執(zhí)行后直接覆蓋所有原始內(nèi)容:

認(rèn)真一點

(8)wb+

以二進(jìn)制讀寫格式打開一個文件。如果該文件已存在,則將其覆蓋。如果該文件不存在,則創(chuàng)建新文件。

(9)a

以追加方式打開一個文件。如果文件已存在,文件指針將會放在文件結(jié)尾。即:新的內(nèi)容將會被追加到已有的內(nèi)容之后。如果該文件不存在,則創(chuàng)建新文件可用于寫入。注意,不能讀,讀會出錯。

(10)a+

以讀寫方式打開一個文件。如果文件已存在,文件指針將會放在文件結(jié)尾。即:新的內(nèi)容將會被追加到已有的內(nèi)容之后。如果該文件不存在,則創(chuàng)建新文件可用于讀寫。

原始內(nèi)容:

認(rèn)真一點

fp = open(r"E:\test.txt",'a+',encoding='utf-8')
fp.write("你就離成功近一點")
fp.close()
fp = open(r"E:\test.txt", 'r', encoding='utf-8')
content = fp.readline()
print(content)
fp.close()

執(zhí)行后追加:

認(rèn)真一點你就離成功近一點

這時候,指針放在文件尾部,直接讀取會沒有內(nèi)容,需要將指針移動(seek)到文件的頭部:

with open(r"E:\test.txt",'a+',encoding='utf-8') as fp:
    fp.seek(0,0)
    content = fp.readline()
    print(content)

(11)ab+

以二進(jìn)制讀寫方式打開一個文件。如果文件已存在,文件指針將會放在文件結(jié)尾。即:新的內(nèi)容將會被追加到已有的內(nèi)容之后。如果該文件不存在,則創(chuàng)建新文件可用于讀寫。

1.3 參數(shù)3

編碼的方式,常用utf-8,gbk等。如:encoding=‘utf-8’

如果是二進(jìn)制的方式,這個參數(shù)不需要填,填了還會報錯。

2.with open() as

這是open()的一種升級用法,控制塊結(jié)束的時候文件會自動關(guān)閉,不需要顯示地調(diào)用close()關(guān)閉文件。這種方法更方便使用,所以推薦大家使用這種方法。

with open(r"E:\test.txt",'r',encoding='utf-8') as fp:
    content = fp.readlines()

3.open函數(shù)常用的方法

3.1 讀

文件內(nèi)容:

認(rèn)真一點你就離成功近一點
啊啊啊啊啊啊啊啊啊啊啊
fffffffffff

(1)read()

一次性讀取整個文件內(nèi)容,將整個文件放到一個字符串中。使用read(size)方法,返回文件中的前size個字符:

content = fp.read()

輸出:

認(rèn)真一點你就離成功近一點
啊啊啊啊啊啊啊啊啊啊啊
fffffffffff

(2)readline()

每次讀取一行內(nèi)容。

content = fp.readline()

輸出:

認(rèn)真一點你就離成功近一點

(3)readlines()

一次性讀取整個文件內(nèi)容到一個迭代器以供我們遍歷(讀取到一個list中,以供使用,比較方便)

content = fp.readlines()

輸出;

[‘認(rèn)真一點你就離成功近一點\n’, ‘啊啊啊啊啊啊啊啊啊啊啊\n’, ‘fffffffffff’]

3.2 寫

(1)write()

fp.write()的參數(shù)必須是一個字符串,就是你要寫入文件的內(nèi)容.

(2)writelines()

fp.writelines()的參數(shù)可以是列表,也可以是字符串。

3.3 獲取文件讀寫類型

如果文件可寫,則 fp.writable() 方法返回 True,否則返回 False。

如果文件是可讀的,則 fp.readable() 方法返回 True,否則返回 False。

比如:以w方式打開的文件,fp.readable()返回False,fp.writable()返回True。

3.4 指針移動

seek

f.seek(偏移量,[起始位置])

起始位置的三種取值:0文件開頭,1當(dāng)前位置,2文件末尾

例子見1.3中(10)a+

3.5 當(dāng)前指針位置

tell()返回一個整數(shù),表示當(dāng)前文件指針的位置(就是到文件頭的字節(jié)數(shù)).

如果是utf-8編碼,那么一個中文字符占用三個字節(jié),一個英文字符占用一個字節(jié)。如果是gbk編碼,那么一個中文字符占用兩個字節(jié),一個英文字符占用一個字節(jié)。

with open(r"E:\test.txt",'a+',encoding='utf-8') as fp:
    content = fp.tell()
    print(content)

打?。?0

3.6 truncate

truncate(size) 方法用于截斷文件,如果指定了可選參數(shù) size,則表示截斷文件為 size 個字符。 如果沒有指定 size,則從當(dāng)前位置起截斷;截斷之后 size 后面的所有字符被刪除。

總結(jié)

到此這篇關(guān)于python使用open函數(shù)對文件進(jìn)行處理的文章就介紹到這了,更多相關(guān)python open函數(shù)使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決Keras使用GPU資源耗盡的問題

    解決Keras使用GPU資源耗盡的問題

    這篇文章主要介紹了解決Keras使用GPU資源耗盡的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • Python爬蟲包BeautifulSoup簡介與安裝(一)

    Python爬蟲包BeautifulSoup簡介與安裝(一)

    這篇文章主要為大家詳細(xì)介紹了Python爬蟲包BeautifulSoup的簡介與安裝,具有一定的參考價值,感興趣的朋友可以參考一下
    2018-06-06
  • pyqt實現(xiàn).ui文件批量轉(zhuǎn)換為對應(yīng).py文件腳本

    pyqt實現(xiàn).ui文件批量轉(zhuǎn)換為對應(yīng).py文件腳本

    今天小編就為大家分享一篇pyqt實現(xiàn).ui文件批量轉(zhuǎn)換為對應(yīng).py文件腳本,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python運維自動化之paramiko模塊應(yīng)用實例

    Python運維自動化之paramiko模塊應(yīng)用實例

    paramiko是一個基于SSH用于連接遠(yuǎn)程服務(wù)器并執(zhí)行相關(guān)操作,使用該模塊可以對遠(yuǎn)程服務(wù)器進(jìn)行命令或文件操作,這篇文章主要給大家介紹了關(guān)于Python運維自動化之paramiko模塊應(yīng)用的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • python 用所有標(biāo)點符號分隔句子的示例

    python 用所有標(biāo)點符號分隔句子的示例

    今天小編就為大家分享一篇python 用所有標(biāo)點符號分隔句子的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python 中拼音庫 PyPinyin 用法詳解

    Python 中拼音庫 PyPinyin 用法詳解

    很多朋友問小編怎樣把一批中文文件轉(zhuǎn)拼音命名呢?下面就讓我們來了解 Python 的一個庫 PyPinyin 吧,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • 利用Python解決Excel問題的最佳方案總結(jié)

    利用Python解決Excel問題的最佳方案總結(jié)

    python處理excel文件有很多方法,最開始接觸的是xlrd、xlsxwriter模塊,分別用于excel文件的讀、寫,后來又學(xué)習(xí)了openpyxl模塊,可以同時完成excel文件的讀、寫,下面這篇文章主要給大家介紹了關(guān)于利用Python解決Excel問題的最佳方案,需要的朋友可以參考下
    2023-04-04
  • Python實現(xiàn)自動計算特定格式的時間差

    Python實現(xiàn)自動計算特定格式的時間差

    這篇文章主要介紹了利用Python實現(xiàn)在輸入一個特定格式的時間后,自動獲取前進(jìn)或者后退多少小時之后的時間。感興趣的朋友可以了解一下
    2021-12-12
  • Python實現(xiàn)員工信息管理系統(tǒng)

    Python實現(xiàn)員工信息管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了Python實現(xiàn)員工信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 詳解Python中dict與set的使用

    詳解Python中dict與set的使用

    這篇文章主要介紹了詳解Python中dict與set的使用,是Python入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-08-08

最新評論