python以字符流写入文件_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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值