一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python中read()、readline()和readlines()三者間的區別和用法

Python中read()、readline()和readlines()三者間的區別和用法

2020-11-29 00:31大阿拉伯人 Python

這篇文章主要給大家介紹了關于Python中讀取文件的read()、readline()和readlines()方法三者間的區別和用法,需要的朋友可以參考下

前言

眾所周知在python中讀取文件常用的三種方法:read(),readline(),readlines(),今天看項目是又忘記他們的區別了。以前看書的時候覺得這東西很簡單,一眼掃過,待到用時卻也只知道有這么幾個方法,不懂得它的原理與用法。也許吧,沒有永遠的記憶,況且根本沒有用心去記它。話不多說,來一起看看詳細的介紹:

準備

假設a.txt的內容如下所示:

?
1
2
3
Hello
Welcome
What is the fuck...

一、read([size])方法

read([size])方法從文件當前位置起讀取size個字節,若無參數size,則表示讀取至文件結束為止,它范圍為字符串對象

?
1
2
3
4
5
f = open("a.txt")
lines = f.read()
print lines
print(type(lines))
f.close()

輸出結果:

?
1
2
3
4
Hello
Welcome
What is the fuck...
<type 'str'> #字符串類型

二、readline()方法

從字面意思可以看出,該方法每次讀出一行內容,所以,讀取時占用內存小,比較適合大文件,該方法返回一個字符串對象。

?
1
2
3
4
5
6
7
f = open("a.txt")
line = f.readline()
print(type(line))
while line:
 print line,
 line = f.readline()
f.close()

輸出結果:

?
1
2
3
4
<type 'str'>
Hello
Welcome
What is the fuck...

三、readlines()方法讀取整個文件所有行,保存在一個列表(list)變量中,每行作為一個元素,但讀取大文件會比較占內存。

?
1
2
3
4
5
6
f = open("a.txt")
lines = f.readlines()
print(type(lines))
for line in lines:
 print line,
f.close()

輸出結果:

?
1
2
3
4
<type 'list'>
Hello
Welcome
What is the fuck...

四、linecache模塊

當然,有特殊需求還可以用linecache模塊,比如你要輸出某個文件的第n行:

?
1
2
3
# 輸出第2行
text = linecache.getline(‘a.txt',2)
print text,

對于大文件效率還可以。

下面是其他網友的補充

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
"""
1、讀取文件的三個方法:read()、readline()、readlines()
2、三個方法均可接受一個變量用以限制每次讀取的數據量,通常不使用該變量。
"""
 
"""
關于read()方法:
1、讀取整個文件,將文件內容放到一個字符串變量中
2、如果文件大于可用內存,不可能使用這種處理
"""
file_object = open("test.py",'r') #創建一個文件對象,也是一個可迭代對象
try:
  all_the_text = file_object.read() #結果為str類型
  print type(all_the_text)
  print "all_the_text=",all_the_text
finally:
  file_object.close()
 
"""
關于readline()方法:
1、readline()每次讀取一行,比readlines()慢得多
2、readline()返回的是一個字符串對象,保存當前行的內容
"""
file_object1 = open("test.py",'r')
try:
 while True:
   line = file_object1.readline()
   if line:
     print "line=",line
   else:
     break
finally:
  file_object1.close()
 
"""
關于readlines()方法:
1、一次性讀取整個文件。
2、自動將文件內容分析成一個行的列表。
"""
file_object2 = open("test.py",'r')
try:
 lines = file_object2.readlines()
 print "type(lines)=",type(lines) #type(lines)= <type 'list'>
 for line in lines:
   print "line=",line
finally:
  file_object2.close()

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持

原文鏈接:http://www.jianshu.com/p/a672f39287c4

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲成人免费 | 亚洲爱视频| 羞羞麻豆国产精品1区2区3区 | 性xxx欧美| 亚洲性视频在线观看 | 欧美日韩国产在线人成 | 日韩一级精品视频在线观看 | 天天舔天天操天天干 | 被高跟鞋调教丨vk | 婷婷丁香色综合狠狠色 | 国产成人一区二区三区在线视频 | 国产精品永久免费视频 | 午夜无码片在线观看影院 | 丝袜白浆| 日本人成在线视频免费播放 | 特级夫妻大片免费在线播放 | 精品国产免费一区二区三区 | 免费大秀视频在线播放 | 四虎影视在线观看永久地址 | 欧美性色欧美a在线播放 | 欧美伦理影院 | 艹艹逼| 国产1广场舞丰满老女偷 | 亚洲AV无码国产精品色午夜情 | 色婷亚洲 | 久久91精品国产91久 | 亚洲欧洲日产v特级毛片 | 男gay网站视频免费观看 | 大又大又黄又爽免费毛片 | 我的漂亮朋友在线观看全集免费 | 午夜宅男网 | 女人叉开腿让男人桶 | 午夜电影三级还珠格格 | 成品人视频w免费观看w | 国产videos hd| 日本aaa大片 | 香蕉97超级碰碰碰免费公 | 日本视频免费在线播放 | 国产精品亚洲片在线va | 国产成人精品日本亚洲网址 | 成年人免费在线播放 |