Python文件和流

Treasuring every moment


open函数

open(name[,mode[,buffering]])

mode有四种模式可选择:

  • 'r' 读模式
  • 'w' 写模式
  • 'a' 追加模式
  • 'b' 二进制模式(可添加到其他模式中使用) 'rb' 可读二进制模式
  • '+' 读/写模式

>write():参数为写入的内容
>>> f = open('somefile.txt','w')
f.write('Hello, ')
7
>>> f.write('World!')
6
>>> f.close()
>writelines():参数为一个字符串列表,它会把所有的字符串写入文件,但不会增加新的行

read():参数为指定读多少字符(字节)

>>> f = open('somefile.txt','r')
>>> f.read(4)
'Hell'
>>> f.read(1)
'o'
>>> f.read()
', World!'

readline():读一行,包括换行符也一起读进来
readlines():读取文件的所有行并将其转换为列表返回

管式输出

demo.py

import sys
text = sys.stdin.read()
words = text.split()
wordcount=len(words)
print('Wordcount:',wordcount,'Text:',text)

somefile.txt

Hello,World!

运行程序

$ cat somefile.txt | python demo.py
('Wordcount:', 1, 'Text:', 'Hello,World!')

可以看出,管道符号(|)将一个命令的标准输出和下一个命令的标准输入连接在一起了。

随机访问

以上对文件的操作都是把文件当成流来进行操作,只能按照从头到尾的顺序读取数据。但是我们可以使用类文件对象的方法seek和tell来直接访问感兴趣的部分。

seek(offset[,whence ]):这个方法把当前位置移动到由offset和whence定义的位置。Offset类是一个字节(字符)数,表示偏移量。whence默认是0,表示偏移量是从文件开头开始计算的(这是偏移量必须是非负的)。

>>> f = open('somefile.txt','w')
>>> f.write('0123456789')
>>> f.seek(5)
>>> f.write('hello,world')
>>> f.close()

>>> f = open('somefile.txt')
>>> f.read()
'01234hello,world6789'

tell():返回当前文件的位置

>>> f = open('somefile.txt')
>>> f.read(3)
'012'
>>> f.read(2)
'34'
>>> f.tell()
5
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • .NET Framework将文件视为数据流。流是一系列用字节表示的数据分组。数据流有底层存储介质,这些存储介质通...
    CarlDonitz阅读 706评论 0 0
  • 到目前为止,我们已经使用了 iostream 标准库,它提供了 cin 和 cout 方法分别用于从标准输入读取流...
    资深小夏阅读 153评论 0 0
  • IO作用:解决设备和设备之间数据传输问题,内存->硬盘,硬盘->内存,键盘数据->内存数据存到硬盘上,就做到了永久...
    数据萌新阅读 656评论 0 0
  • 我的博客原文 Python打开文件可以用open函数语法:open(filename, mode[, buffer...
    logging_DEBUG阅读 1,838评论 0 2
  • 我喜欢钱,不要说我庸俗,这只是我的爱好而已。对我来说喜欢钱的人高雅,知性,睿智,因为他们是思想丰富的群体。然而我没...
    艾钱真爱钱阅读 382评论 0 1