python入门(十):文件的操作详解

来源:互联网 发布:往届生银行知乎 编辑:程序博客网 时间:2024/06/07 22:43

1.三种基本的文件操作模式:r(only-read)、w(only-write)、a(append)

   (1)r模式

     read()

f = open('yesterday.txt', 'r')f_read = f.read()   #read是逐字符地读取,read可以指定参数,设定需要读取多少字符,无论一个英文字母还是一个汉字都是一个字符。print(f_read)f.close()
    readline()

f = open('yesterday.txt', 'r')f_read = f.readline() #readline只能读取第一行代码,原理是读取到第一个换行符就停止。print(f_read)f.close()

    readlines()

f = open('yesterday.txt', 'r')f_read = f.readlines() #readlines会把内容以列表的形式输出。print(f_read)f.close()

   通过for循环读取(常用)

f = open('yesterday.txt', 'r')for line in f:    print(line)


     (2)w模式

在进行操作前,文件中所有内容会被清空。比如在file1中写入'hello world',程序执行后file1中就只剩下一句'hello world'

f = open('yesterday.txt', 'w', encoding='utf8')  #由于Python3的默认编码方式是Unicode,所以在写入文件的时候需要调用utf8,以utf8的方式保存,这时pycharm(默认编码方式是utf8)才能正确读取,当读取文件时,文件是utf8格式,pycharm也是utf8,就不需要调用了。f_w = f.write('hello world')print(f_w)  #有意思的是,这里并不打印'hello world',只打印写入多少字符f.close()

   

    (3)a模式

与w模式不同的是,a模式不会把原来内容清空,而是光标移到内容最后位置,继续写入新内容。比如在最后追加'hello world'

f = open('yesterday.txt', 'a')f_a = f.write('\nhello world')print(f_a)  # 还是会打印写入的字符数f.close()


2.tell和seek

     tell:查询文件中光标位置

     seek:光标定位


f = open('yesterday.txt','r')print(f.tell())#光标默认在起始位置f.seek(10)#把光标定位到第10个字符之后print(f.tell())#输出10f.close()

3.flush同步将数据从缓存转移到磁盘

(示例:实现进度条功能)

import sysimport time  #导入sys和time模块for i in range(40):    sys.stdout.write('*')#当我们在 Python 中打印对象调用 print obj 时候,事实上是调用了 sys.stdout.write(obj+'\n')#print 将你需要的内容打印到了控制台,然后追加了一个换行符#print 会调用 sys.stdout 的 write 方法#以下两行在事实上等价:#sys.stdout.write('hello'+'\n')#print 'hello'    sys.stdout.flush()  #flush的作用相当于照相,拍一张冲洗一张    time.sleep(0.2)

5.truncate 截断

不能是r模式下执行,

w模式下,已经清空所有数据,使用truncate没有任何意义,

a模式下,截断指定位置后的内容。

?
1
2
f=open('file','a')
f.truncate(6)#只显示6个字节的内容(6个英文字符或三个汉字),后面的内容被清空
6.另外3种模式:r+、w+、a+
      r+:读写模式,光标默认在起始位置,当需要写入的时候,光标自动移到最后
     w+:写读模式,先清空原内容,再写入,也能够读取
     a+:追加读模式,光标默认在最后位置,直接写入,也能够读取。


7.通过with语句自动关闭文件

使用open,一是可能忘记关闭文件句柄;二是文件读取数据发生异常,没有进行任何处理。with open可解决这两个问题:

with open("yesterday.txt", 'r', encoding='utf-8') as f:    for line in f:        print(line)

num = 0with open('yesterday.txt','r') as f1,open('user.txt','w',encoding='utf8') as f2:  for line in f1:    num += 1    if num == 5:      line = ''.join([line.strip(),'羊小羚'])    f2.write(line)