python学习记录——文件操作

打开文件的模式有三种:

  • r,只读模式(默认)。

  • w,只写模式。(不可读;不存在则创建;存在则删除内容;因为会清空覆盖原有文件的内容,一定要慎用)

  • a,追加模式。(可读;   不存在则创建;存在则只追加内容)

注意最后要记得关闭文件:f.close()
python只能将字符串写入到文本文件。要将数值数据存储到文本本件中,必须先试用函数str()将其转换为字符串格式。

1、r模式(只读模式)

f = open(r'D:\python\test.txt')
data = f.read()
f.close()
print(data)

#只读文件的前5行:

f = open(r'D:\python\test.txt','r',encoding='utf-8')
for i in range(5):
    print(f.readline())

#以列表的方式读取这个文件

f = open(r'D:\python\test.txt','r',encoding='utf-8')
for line in f.readlines():
    print(line)

#对文件的第3行,做一个特殊的打印(这种方式比较低效,因为它会先把文件全部读取到内存中,文件较大时会很影响性能)
 

f = open(r'D:\python\test.txt','r',encoding='utf-8')
for index,line in enumerate(f.readlines()):
    if index == 2:
        print('-----测试线----',line)
        continue
    print(line)

#比较高效的,逐行读取文件内容,因为它是一行一行的去读取文件,不会先把文件一次性全部读取到内存中
 

f = open(r'D:\python\test.txt','r',encoding='utf-8')
for line in f:
    print(line)

#比较高效的,对文件的3三行进行过特殊打印

f = open(r'D:\python\test.txt','r',encoding='utf-8')
count = 0
for line in f:
    if count == 2:
        print('------测试线----:',line)
    count += 1
    print(line)

2、w模式(只写模式)

f = open(r'D:\python\test.txt', 'w', encoding='utf-8')
f.write("写入内容测试\n")
f.write("写入内容测试1")

3、a模式(追加模式)

f = open(r'D:\python\test.txt', 'a', encoding='utf-8')
f.write("test1\n")

4、常用文件方法

close() 方法用于关闭一个已打开的文件。关闭后的文件不能再进行读写操作, 否则会触发 ValueError 错误。 close() 方法允许调用多次。当 file 对象,被引用到操作另外一个文件时,Python 会自动关闭之前的 file 对象。 使用 close() 方法关闭文件是一个好的习惯。

  • close() 方法语法:file.close()

flush() 方法是用来刷新缓冲区的,即将缓冲区中的数据立刻写入文件,同时清空缓冲区,不需要是被动的等待输出缓冲区写入。一般情况下,文件关闭后会自动刷新缓冲区,但有时你需要在关闭前刷新它,这时就可以使用 flush() 方法。

  • flush() 方法语法:file.flush()

fileno() 方法返回一个整型的文件描述符(file descriptor FD 整型),可用于底层操作系统的 I/O 操作。

  • fileno() 方法语法:file.fileno()

isatty() 方法检测文件是否连接到一个终端设备,如果是返回 True,否则返回 False。

  • isatty() 方法语法:file.isatty()

next() 通过迭代器调用 __next__() 方法返回下一项。 在循环中,next()方法会在每次循环中调用,该方法返回文件的下一行,如果到达结尾(EOF),则触发 StopIteration

  • next() 方法语法:next(iterator[,default])

read() 方法用于从文件读取指定的字节数,如果未给定或为负则读取所有。

  • read() 方法语法:file.read(size)

参数

  • size -- 从文件中读取的字节数。

readline() 方法用于从文件读取整行,包括 "\n" 字符。如果指定了一个非负数的参数,则返回指定大小的字节数,包括 "\n" 字符。

  • readline() 方法语法:file.readline()

参数

  • size -- 从文件中读取的字节数。

seek() 方法用于移动文件读取指针到指定位置。

  • seek() 方法语法:file.seek(offset[, whence])

参数

  • offset -- 开始的偏移量,也就是代表需要移动偏移的字节数

  • whence:可选,默认值为 0。给offset参数一个定义,表示要从哪个位置开始偏移;0代表从文件开头开始算起,1代表从当前位置开始算起,2代表从文件末尾算起。

tell() 方法返回文件的当前位置,即文件指针当前位置。

  • tell() 方法语法:file.tell(offset[, whence])

truncate() 方法用于从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后后面的所有字符被删除,其中 Widnows 系统下的换行代表2个字符大小。 

  • truncate() 方法语法:file.truncate( [ size ])

参数

  • size -- 可选,如果存在则文件截断为 size 字节。

write() 方法用于向文件中写入指定字符串。

在文件关闭前或缓冲区刷新前,字符串内容存储在缓冲区中,这时你在文件中是看不到写入的内容的。

如果文件打开模式带 b,那写入文件内容时,str (参数)要用 encode 方法转为 bytes 形式,否则报错:TypeError: a bytes-like object is required, not 'str'。

  • write() 方法语法:file.write( [ str ])

参数

  • str -- 要写入文件的字符串。

writelines() 方法用于向文件中写入一序列的字符串。

这一序列字符串可以是由迭代对象产生的,如一个字符串列表。

换行需要制定换行符 \n。

  • writelines() 方法语法:fileObject.writelines( [ str ])

参数

  • str -- 要写入文件的字符串序列。

5、r+ 、w+、a+ 模式(读,追加模式)

f = open(r'D:\python\test.txt', 'r+', encoding='utf-8')
data = f.read()
print(data)
f.write("test...\n")

r+ 可读可写,不会创建不存在的文件,从顶部开始写,会覆盖之前此位置的内容
w+ 可读可写,如果文件存在,则覆盖整个文件,不存在则创建
a+ 可读可写 从文件顶部读取内容 从文件底部添加内容 不存在则创建
#rb 模式,以二进制的方式读取这个文件
#wb 模式,二进制写

6、with语句

每次读写完文件之后,都要f.close()关闭文件,因为文件对象会占用操作系统的资源,并且操作系统同一时间能打开的文件数量也是有限的。

但是实际中,文件读写可能产生IOError,一旦出错,后面的f.close()就不会调用。所以,为了保证任何时候都能关闭文件,可以使用try-finally来实现(finally内的代码不管有无异常发生,都会执行)

try:
    f = open(r'D:\python\test.txt', 'r')
    print(f.read())

except IOError as reason:
    print('出错了:' + str(reason))
    
finally:
        f.close()

每次都这样写实在是麻烦,python中的with语句用法可以实现:

with open(r'D:\python\test.txt', 'r') as f:
    print(f.read())

猜你喜欢

转载自blog.csdn.net/showgea/article/details/81181413