Python-循环遍历文件
发布日期:2021-05-07 19:07:37 浏览次数:26 分类:精选文章

本文共 1291 字,大约阅读时间需要 4 分钟。

python中打开文件需要使用内置函数open

格式:

  open(name[,mode[,buffering]])
  启动mode和buffering 是可选的,默认情况下mode是r
 

mode:

  r:以读方式打开
  w:以写方式打开 (文件不存在会创建,存在的话,会清空文件,很危险)
  a:以追加的方式打开
  r+:以读写模式打开
  w+:以读写模式打开
  a+:以读写模式打开
  rb:以二进制读模式打开(特殊文件需要用文本模式传输的话,建议使用b)
  wb:以二进制写模式打开
  ab:以二进制追加模式打开
 
 

方法:

  fd = open('/tmp/test.txt','r')
  以读模式打开,可以利用一个变量去接收,注意这个变量是一个文件对象
 
  fd.close()
  关闭打开的文件,(修改等操作,只有关闭了文件,才会生效)
 
  fd.write("123")
  写入(需要写模式),注意写入的内容必须是一个字符串。
 
  fd.read(int)
  一次性读取文件所有内容,那么再次执行read()方法的时候,指针在末尾,所以就为空了。如果指定了int,那么就只读取int个字符
 
  fd.readline()
  一行一行读取,返回字符串,当指针到文件默认,返回空
 
  fd.readlines()
  一次读取所有行,并把每一个行当成一个元素,存储在序列中(如果文件很大,那么非常占内存)
 
  fd.next()
  第一读取一行,知道行尾,到行尾的时候会报错
 
 

练习:

  for 循环遍历文件:
打印文件的每一行
#!/usr/bin/env pythonfd = open('/tmp/hello.txt')  for line in fd:    print line,
注意:这里for line in fd,其实可以从fd.readlines()中读取,但是如果文件很大,那么就会一次性读取到内存中,非常占内存,而这里fd存储的是对象,只有我们读取一行,它才会把这行读取到内存中,建议使用这种方法。
 
  while循环遍历文件:
#!/usr/bin/env pythonfd = open('/tmp/hello.txt')while True:  line = fd.readline()  if not line:    break
   else:    print line,fd.close()
 

扩展:

    如果不想每次打开文件都关闭,可以使用with关键字,2.6以上版本支持with读取 with open('/tmp/hello.txt') as fd: 然后所有打开文件的操作都需要缩进,包含在with下才行
with open('/tmp/hello.txt') as fd:while True:  line = fd.readline()  if not line:    break
    
else:
    
print
line,

 

所有巧合的是要么是上天注定要么是一个人偷偷的在努力。
上一篇:解除文件占用
下一篇:爬虫数据老不好,需要缓存来断点续爬实现

发表评论

最新留言

关注你微信了!
[***.104.42.241]2025年04月11日 01时54分33秒