打开和关闭文件:
Python 提供了必要的函数和方法进行默认情况下的文件基本操作。
open 函数
你必须先用Python内置的open()函数打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写。
语法:
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+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
x | 如果文件存在,打开将引发异常 |
一个文件被打开后,你有一个file对象,你可以得到有关该文件的各种信息。
以下是和file对象相关的所有属性的列表:
f.closed() | 如果文件已被关闭返回true,否则返回false. |
f.mode() | 返回被打开文件的访问模式 |
f.name() | 返回文件的名称。 |
f.softspace() | 如果用print输出后,必须跟一个空格符,则返回false。否则返回true。 |
close()方法
File 对象的 close()方法刷新缓冲区里任何还没写入的信息,并关闭该文件,这之后便不能再进行写入。当一个文件对象的引用被重新指定给另一个文件时,Python 会关闭之前的文件。用 close()方法关闭文件是一个很好的习惯。
语法:
fileObject.close()
# 打开一个文件 f1 = open("f.txt", "w") print "文件名: ", f1.name # 关闭打开的文件 f1.close()
读写文件:
file对象提供了一系列方法,能让我们的文件访问更轻松。来看看如何使用read()和write()方法来读取和写入文件。
read()方法
read()方法从一个打开的文件中读取一个字符串。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。
语法:
fileObject.read([count]) ##无参数,读全部;有参数,(b,按字节 |无b,按字符)
被传递的参数是要从已打开文件中读取的字节计数。该方法从文件的开头开始读入,如果没有传入count,它会尝试尽可能多地读取更多的内容,直到文件的末尾。
文件定位
tell()方法告诉你文件内的当前位置;获取当前指针位置,下一次的读写会发生在文件开头这么多字节之后。
seek(offset [,from])方法改变当前文件的位置。Offset变量表示要移动的字节数。From变量指定开始移动字节的参考位置。
如果from被设为0,这意味着将文件的开头作为移动字节的参考位置。如果设为1,则使用当前的位置作为参考位置。如果它被设为2,那么该文件的末尾将作为参考位置。
write()方法
write()方法可将任何字符串写入一个打开的文件。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。
write()方法不会在字符串的结尾添加换行符(‘\n‘)
语法:
fileObject.write(string)
被传递的参数是要写入到已打开文件的内容,有b,写字节;无b,写字符。
flush()方法
强制刷新文件内部缓冲区,写进文件
file 对象常用的函数:
方法 | 描述 |
f.close() | 关闭文件。关闭后文件不能再进行读写操作。 |
f.flush() | 刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。 |
f.fileno() | 返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。 |
f.isatty() | 如果文件连接到一个终端设备返回 True,否则返回 False。 |
f.next() | 返回文件下一行。 |
f.read([size]) | 从文件读取指定的字节数,如果未给定或为负则读取所有。 |
f.readline() | 读取整行,包括 "\n" 字符。 |
f.seek(offset[, whence]) | 设置文件当前位置 |
f.tell() | 返回文件当前位置。 |
f.truncate([size]) | 截取文件,截取的字节通过size指定,默认为当前文件位置。 |
f.write(str) | 将字符串写入文件,没有返回值。 |
f.writelines(sequence) | 向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。 |
with方式打开文件
with open(‘db‘) as f1, open(‘db2‘) as f2: pass
本文出自 “LE” 博客,请务必保留此出处http://lz001.blog.51cto.com/8294567/1795399
原文地址:http://lz001.blog.51cto.com/8294567/1795399