日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

关于python3的readlines(),read()和readline()简介

發(fā)布時(shí)間:2024/4/18 python 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 关于python3的readlines(),read()和readline()简介 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

關(guān)于python的readlines(),readline(),read()的介紹

1.read()

這個(gè)函數(shù)是把一個(gè)文檔當(dāng)成一個(gè)字符串(結(jié)尾有空字符串)返回。也就是一個(gè)文檔存儲(chǔ)在一個(gè)字符串對(duì)象中,如果文件很大,就很耗內(nèi)存。

注:read()和原來的文檔相比,輸出的時(shí)候結(jié)尾多了一個(gè)'\n'(換行),其余沒區(qū)別

如果想要輸出和原文檔一模一樣,需要在結(jié)果加rstrip(),也就是去掉末尾空格,例如:

有一個(gè)文件pi_digits.txt,內(nèi)容如下:

pi_digits.txt

3.143453453452342653453445345123656

1.py如下

file_name = 'pi_digits.txt' with open(file_name) as f:contents = f.read() print(contents) print(contents.rstrip())

運(yùn)行1.py結(jié)果如下:

3.1434534534523426534534453451236563.143453453452342653453445345123656

顯然第一個(gè)末尾多一個(gè)空行,第二次和原文檔一樣。

2.readlines(),是把一個(gè)文檔的每一行(包含行前的空格,行末加一個(gè)\n),作為列表的一個(gè)元素,存儲(chǔ)在一個(gè)list中。每一個(gè)行作為list的一個(gè)元素。

注意:readlines()和原文檔相比,每行之后都多出一個(gè)空行,因?yàn)樵瓉砻啃心┪捕技恿?#39;\n',要想和原文檔輸出一樣,那么每個(gè)行末尾加上rstrip()即可消除右邊空格,左邊空格不變。

3.readline(),類似于readlines(),不過它每次只讀取文檔的一行。以后需要逐步循環(huán)(一般用whicl循環(huán)),最后遍歷整個(gè)文件。

注意:輸出情況同readlines()

4.直接使用open() 返回的對(duì)象,例如:

file_name = 'pi_digits.txt' f1 = open(file_name) #這里f1在原來的每行末尾都放置了一個(gè)'\n',print本身也會(huì)加一個(gè)'\n',所以每行輸出后多兩個(gè)'\n', #兩次換行的結(jié)果是行和行之間夾著一個(gè)空行 for line in f1:print(line)

輸出如下:

3.143453453452342653453445345123656

注意:直接使用open()返回對(duì)象,并且把這個(gè)對(duì)象逐行讀取后和readlines()后逐行讀取是一樣的。

open()會(huì)把原來的文檔對(duì)象保存到一個(gè)變量中。且在原來的每行末尾加一個(gè)看不見的'\n',我們姑且當(dāng)成是直接打包一個(gè)文件(每行多加一個(gè)'\n')。逐行讀取的時(shí)候和readlines()是一樣的。但是readlines()會(huì)把一個(gè)文件以行為單位放在一個(gè)list中,但是

open()結(jié)果是把一個(gè)文檔整體打包。但是open()返回對(duì)象和readlines()還有一個(gè)區(qū)別,readlines()返回的對(duì)象可以在with代碼塊之外使用,但是open()返回的對(duì)象只能在with代碼塊內(nèi)使用。

file_name = 'pi_digits.txt' with open(file_name) as f1: #下面的for代碼塊使用了f1,必須有縮進(jìn),因?yàn)槭褂胒1只能在with代碼塊內(nèi)使用for line in f1:print(line)with open(file_name) as f2:lines = f2.readlines() #下面的for語句可以有縮進(jìn)也可以沒有縮進(jìn),有縮進(jìn)就意味著在with代碼塊內(nèi),沒有縮進(jìn)意味著在with代碼塊外 #使用,這兩種都是可以的,所以相對(duì)而言,readlines()返回對(duì)象有更大的自由度 for line in lines:print(line.rstrip())~

注意:readlines()返回對(duì)象可以在with代碼塊外使用,但是open()返回對(duì)象只能在with代碼塊內(nèi)使用

?

?

與50位技術(shù)專家面對(duì)面20年技術(shù)見證,附贈(zèng)技術(shù)全景圖

總結(jié)

以上是生活随笔為你收集整理的关于python3的readlines(),read()和readline()简介的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。