Python文件对象和方法

1.打开和关闭文件

Python提供了必要的函数和方法进行默认情况下的文件基本操作,我们可以用file对象做大部分文件操作。
open()方法
我们必须先用Python内置的open()函数打开一个文件,创建一个file对象,才能调用其相关的方法对它进行读写。其语法是:

file object = open(file_name [, access_mode][, buffering])
file object = open(file_name [, access_mode][, buffering])

各个参数的细节如下:

  • file_name:file_name变量是一个包含了我们要访问的文件名称的字符串值;
  • access_mode:access_mode决定了打开文件的模式:只读、写入、追加等;所有可取值见如下完全的列表,这个参数是非强制的,默认文件访问模式为只读(r);
  • buffering:如果buffering的值被设置为0,就不会有寄存,如果buffering的值为1,访问文件时会寄存行。如果将buffering的值设置为大于1的整数,表明了这就是寄存区的缓冲大小,如果取负值,寄存区的缓冲大小则为系统默认;

不同模式打开文件的完全列表:

模式

描述

r

以只读方式打开文件,文件的指针将会放在文件的开头,这是默认模式

rb

以二进制格式打开一个文件用于只读,文件指针将会放在文件的开头,这是默认模式。一般用于非文本文件,如:图片、音频、视频等

r+

打开一个文件用于读写,文件指针将会放在文件的开头

rb+

以二进制格式打开一个文件用于读写,文件指针将会放在文件的开头。一般用于非文本文件,如:图片、音频、视频等

w

打开一个文件只用于写入,如果该文件已经存在则将其覆盖,如果该文件不存在,创建新文件

wb

以二进制格式打开一个文件只用于写入,如果该文件已经存在则将其覆盖,如果该文件不存在,创建新文件。一般用于非文本文件,如:图片、音频、视频等

w+

打开一个文件用于读写,如果该文件已经存在则将其覆盖,如果该文件不存在,创建新文件

wb+

以二进制格式打开一个文件用于读写,如果该文件已经存在则将其覆盖,如果该文件不存在,创建新文件。一般用于非文本文件,如:图片、音频、视频等

a

打开一个文件用于追加,如果该文件已存在,文件指针将会放在文件的结尾,也就是说,新的内容将会被写入到已有内容之后,如果该文件不存在,创建新文件进行写入

ab

以二进制格式打开一个文件用于追加,如果该文件已存在,文件指针将会放在文件的结尾,也就是说,新的内容将会被写入到已有内容之后,如果该文件不存在,创建新文件进行写入

a+

打开一个文件用于读写,如果该文件已存在,文件指针将会放在文件的结尾,也就是说,新的内容将会被写入到已有内容之后,如果该文件不存在,创建新文件进行写入

ab+

以二进制格式打开一个文件用于追加,如果该文件已存在,文件指针将会放在文件的结尾,也就是说,新的内容将会被写入到已有内容之后,如果该文件不存在,创建新文件进行写入

下图很好的总结了这几种模式:

python中创建文件的函数 python中创建文件对象方法_Python

File对象的属性
一个文件被打开后,我们就有一个file对象,接下来就可以得到该文件的各种信息,以下是和file对象相关的所有属性的列表:

属性

描述

file.closed

如果文件已被关闭,返回true,否则返回false

file.mode

返回被打开文件的访问模式

file.name

返回文件的名称

file.softspace

如果用print输出后,必须跟一个空格符,则返回false,否则返回true

如下实例:

fo = open("foo.txt", "w")
print("文件名:", fo.name)
print("访问模式:", fo.mode)
print("是否已关闭:", fo.closed)
fo = open("foo.txt", "w")
print("文件名:", fo.name)
print("访问模式:", fo.mode)
print("是否已关闭:", fo.closed)

运行输出结果为:

文件名: foo.txt
访问模式: w
是否已关闭: False

close()方法
File对象的close()方法刷新缓冲区里任何还没写入的信息,并关闭该文件,之后便不能在进行写入。当一个文件对象的引用被重新指定给另一个文件时,Python会关闭之前的文件。用close()方法关闭文件是一个很好的习惯,其语法是:

fileObject.close()
fileObject.close()

如上面实例:

# 打开一个文件
fo = open("foo.txt", "w")
print("文件名:", fo.name)
print("访问模式:", fo.mode)
print("是否已关闭:", fo.closed)

# 关闭打开的文件
fo.close()
# 打开一个文件
fo = open("foo.txt", "w")
print("文件名:", fo.name)
print("访问模式:", fo.mode)
print("是否已关闭:", fo.closed)

# 关闭打开的文件
fo.close()

读写文件,file对象提供了一系列方法,能让我们的文件访问更轻松,接下来我们就将使用read()和write()方法来读取和写入文件。
write()方法
write()方法可将任何字符串写入一个打开的文件,需要重点注意的是,Python字符串可以是二进制数据,而不仅仅是文字。write()方法不会在字符串的结尾添加换行符("\n"),其语法为:

fileObject.write(string)
fileObject.write(string)

在这里,被传递的参数是要写入到已打开文件的内容,如下实例:

# 打开一个文件
fo = open("foo.txt", "w")
fo.write("www.baidu.com!\nVery good site!\n")

# 关闭打开的文件
fo.close()
# 打开一个文件
fo = open("foo.txt", "w")
fo.write("www.baidu.com!\nVery good site!\n")

# 关闭打开的文件
fo.close()

上述方法会创建foo.txt文件,并将收到的内容写入该文件,并最终关闭文件。打开该文件,我们将会看到以下内容:

www.baidu.com!
Very good site!

read()方法
read()方法从一个打开的文件中读取一个字符串,需要重点注意的是,Python字符串可以是二进制数据,而不仅仅是文字,其语法为:

fileObject.read([count])
fileObject.read([count])

在这里,被传递的参数是要从已打开的文件中读取的字节数,该方法从文件的开头开始读取,如果没有传入count,它会尝试尽可能多的读取更多的内容,很可能是直到文件的末尾,如下实例:

fo = open("foo.txt", "r+")
content = fo.read(14)
print("读取的字符串是:{}".format(content))

# 关闭打开的文件
fo.close()
fo = open("foo.txt", "r+")
content = fo.read(14)
print("读取的字符串是:{}".format(content))

# 关闭打开的文件
fo.close()

运行输出结果为:

读取的字符串是:www.baidu.com!

文件定位
tell()方法告诉我们文件内的当前位置,换句话说,下一次的读写将会发生在文件开头多少字节之后。seek(offset[, from])方法改变当前文件的位置,offset变量表示要移动的字节数,from变量指定开始移动字节的参考位置。如果from被设为0,这意味着将文件的开头作为移动字节的参考位置,如果设为1,则使用当前的位置作为参考位置,如果它被设为2,那么该文件的末尾将作为参考位置。如下实例:

# 打开一个文件
fo = open("foo.txt", "r+")
content = fo.read(14)
print("读取的字符串是:", content)

# 查找当前位置
position = fo.tell()
print("当前文件位置:", position)

# 把文件指针再次重新定位到文件开头
position = fo.seek(0, 0)
con = fo.read(14)
print("重新读取字符串:", con)

# 关闭文件
fo.close()
# 打开一个文件
fo = open("foo.txt", "r+")
content = fo.read(14)
print("读取的字符串是:", content)

# 查找当前位置
position = fo.tell()
print("当前文件位置:", position)

# 把文件指针再次重新定位到文件开头
position = fo.seek(0, 0)
con = fo.read(14)
print("重新读取字符串:", con)

# 关闭文件
fo.close()

运行输出结果为:

读取的字符串是: www.baidu.com!
当前文件位置: 14
重新读取字符串: www.baidu.com!

重命名和删除文件 Python的os模块提供了帮助我们执行文件处理操作的方法,比如重命名和删除文件。要使用这个模块,必须先导入它,然后才可以调用相关的功能

2.Python 文件常用方法

file对象使用open()方法来创建,下表列出了file对象常用的方法:

方法

描述

file.close()

关闭文件,关闭后文件不能再进行读写操作

file.flush()

刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件,而不是被动的等待输出缓冲区写入

file.fileno()

返回一个整型的文件描述符(file description FD整型),可以用在如os模块的read方法等一些底层操作上

file.isatty()

如果文件连接到一个终端设备返回true,否则返回false

file.read([size])

从文件读取指定的字节数,如果未给定或为负数则读取所有

file.readline([size])

读取整行,包括"\n"字符

file.readlines([sizeint])

读取所有行并返回列表,若给定sizeint>0,则是设置一次读多少字节,这是为了减轻读取压力

file.seek(offset[, whence])

设置文件当前位置

file.tell()

返回文件位置

file.truncate([size])

截取文件,截取的直接通过size指定,默认为当前文件位置

file.write(str)

将字符串写入文件,没有返回值

file.writelines(sequence)

向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符

3.Python With语句

在Python中,我们在打开文件时,为了代码的健壮性,通常要考虑一些异常情况,比如:

try:
    conf_file = open("logging.conf")
    content = conf_file.readlines()
    conf_file.close()

except IOError:
    log.write("No such file read!")
try:
    conf_file = open("logging.conf")
    content = conf_file.readlines()
    conf_file.close()

except IOError:
    log.write("No such file read!")

如果文件操作出现异常,则写一条错误日志;考虑一种情况,如果文件成功打开了,但readlines()调用失败,异常处理会立即跳转到except处执行,这样文件关闭就没有机会被执行到。一种解决方案就是将close()语句放到finally子句中去,finally的特点是不管有无异常,都会被执行:

try:
    try:
        conf_file = open("logging.conf")
        content = conf_file.readlines()

    except IOError:
        log.write("No such file read!")

finally:
    conf_file.close()
try:
    try:
        conf_file = open("logging.conf")
        content = conf_file.readlines()

    except IOError:
        log.write("No such file read!")

finally:
    conf_file.close()

或者

try:
    try:
        conf_file = open("logging.conf")
        content = conf_file.readlines()

    finally:
        conf_file.close()

except IOError:
    log.write("No such file read!")
try:
    try:
        conf_file = open("logging.conf")
        content = conf_file.readlines()

    finally:
        conf_file.close()

except IOError:
    log.write("No such file read!")

但是上面的语句很不优雅,在Python中我们可以使用with语句来优雅的处理该问题:

with open("logging.conf") as f:
    for line in f:
        print(line)
with open("logging.conf") as f:
    for line in f:
        print(line)

with语句仅仅能对支持上下文管理协议的对象使用,支持此协议的对象有:

file
decimal.Context
thread系列

with语句执行的解析:

with context_expr() as var:
    dosomething()
with context_expr() as var:
    dosomething()
  • 1.当with语句执行时,便执行上下文表达式(context_expr一般为某个方法)来获得一个上下文管理器对象,上下文管理器的职责是提供一个上下文对象,用于在with语句块中处理细节;
  • 2.一旦获得了上下文对象,就会调用它的__enter__()方法,将完成with语句块执行前的所有准备工作,如果with语句后面跟了as语句,则用__enter__()方法的返回值来赋值;
  • 3.当with语句块结束时,无论是正常结束还是异常结束,都会调用上下文对象的__exit__()方法,exit()方法有3个参数,如果with语句正常结束,3个参数全部都是None;如果发生异常,3个参数的值分别等于调用sys.exc_info()函数返回的3个值:类型(异常类)、值(异常实例)和跟踪记录(traceback),相应的跟踪记录对象;
  • 4.因为上下文管理器主要作用于共享资源,enter()和__exit__()方法基本是完成分配和释放资源的低层次工作,比如:数据库连接、锁分配、信号量加/减、状态管理、文件打开/关闭、异常处理等;