一、open函数:对文件读写之前,需要先打开文件,获取文件句柄

注意:open() file() 尽量使用open(),Python3以后不支持file()了

1、open(file_name[,access_mode][,buffering])

(1)参数说明

file_name:一个包含了你要访问的文件路径及文件名称的字符串值。尽量使用绝对路径

access_mode:打开文件的方式:这个参数是非强制的,默认文件访问模式为只读(r)

r,只读

w:写之前会清空文件的内容

a:追加的方式,在原本内容中继续写

buffering:先写到缓存中

如果buffering的值被设置为0,就不会有寄存;如果值为1,访问文件时会缓存行;如果值位大于1的整数,表明了这就是寄存区的缓冲大小;如果取负值,寄存区的缓冲大小则为系统默认。该参数也是非强制性的。

(2)返回值

该语句表示返回的File_object是一个指向文件的指针(一个文件对象)文件句柄。当以只读模式(r)打开一个不存在的文件时,就会报IOError异常(文件不存在),但如果是以写或追加模式(w/a/a+)打开一个不存在的文件时,默认会创建该文件,但如果是所在路径中有目录不存在,也会报IOError异常

 创建一个文件:

fp=open('d:\\tmp\\01.txt',w)

 

2、mode文件操作模式

r,w,a

r+可读可写

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

a+:打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。

 rb wb ab 读写二进制

 

3、通过open获取到的文件句柄可以对文件作的其他操作

(1)fp.closed

判断文件是否已经关闭。返回true如果文件已被关闭,否则返回false

(2)fp.mode

输出读写模式。返回被打开文件的访问模式。

(3)fp.name:

返回文件的名称。

(4) fp.softspace

如果用print输出后,是否跟一个空格符,false不打印,true则打印。

(5)fp.close()

刷新缓冲区里任何还没写入的信息,并关闭该文件,这之后便不能再进行写入。

(6)flush()

把缓冲区中的内容持久化写到磁盘里

缓存区写满的情况,系统会自动调用flush()方法。

调用flush的时机:写入了多少长度的数据,或者间隔了多长的时间

如果没有flush(),持久化内容丢失

(7)next()

# for i in fp:
# print i

把一个file用for...in file这样的循环遍历语句时,就是调用next()函数来实现。

文件句柄是一个迭代器???

fp=open(fileName,'r')
 
print fp.next()
print fp.next()
print fp.fileno() 判断当前操作的文件句柄是哪一个number
fp.close()

 

(8)裁剪文件truncate([size])

用于截断文件,如果指定了可选参数 size,则表示截断文件为 size 个字符。 如果没有指定 size,则从当前位置起截断;截断之后 size 后面的所有字符被删除。

如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。

fp='e:\\tmp\\03.txt'
 
f1=open(fp,'r+')
line=f1.readline()
print line
 
f1.truncate()
print f1.tell()
f1.close()

 

二、对文件作读写操作

1、常规的读写操作

(1)read([size])

size:读取的长度,以byte为单位。如果不指定参数,表示一次性读取全部内容,以字符串形式返回,并且每一行结尾会有一个"\n"符号。

 

(2)、readline([size])

调一次读取一行,如果给定了size,有可能返回的只是一行的一部分,以字符串的形式返回,并且结尾会有一个换行符"\n"。读完一行,文件操作标记移动到下一行的开头。

返回的是字符串

 

(3)、readlines([size])

(3.1)参数

size:指定很小的数字,会不生效,python 默认8k缓存区大小,需要大于8k生效

读取文件的全部内容,这个函数的内部是通过循环调用readline()来实现的

(3.2)返回值

返回的是列表格式,每一行是列表的一个元素,并且结尾会有一个换行符"\n"

 

(4)、writelines(seq)

seq:把seq(序列)的内容全部写到文件中(多行一次性写入)。也不会自动加入换行符。

注意:序列中的内容也必须是字符串类型的数据,才能成功写入文件。

 

(5)、write(str)

把str写到文件中,默认是不加换行符的,所以如果想换行的话,得手动加入换行符'\n'。

 

2、使用linecache模块读取文件

import linecache

允许从任何文件里得到任何的行,并且使用缓存进行优化,常见的情况是从单个文件读取多行。

(1)linecache.getlines(filename,lineno)

从名为 filename 的文件中得到第 lineno 行。

这个函数从不会抛出一个异常–产生错误时它将返回”(换行符将包含在找到的行里)。

如果文件没有找到,这个函数将会在 sys.path 搜索。

(2)linecache.getlines(filename) 返回列表

从名为 filename 的文件中得到全部内容,输出为列表格式,以文件每行为列表中的一个元素,并以 linenum-1 为元素在列表中的位置存储

(3)linecache.clearcache()

清除缓存,如果你不再需要先前从 getline() 中得到的行

(4)linecache.checkcache([filename])

检查缓存的有效性。如果在缓存中的文件在硬盘上发生了变化,并且你需要更新版本,使用这个函数。

如果省略 filename,将检查缓存里的所有条目。

(5)linecache.updatecache(filename)

更新文件名为 filename 的缓存。如果 filename 文件更新了,使用这个函数可以更新

linecache.getlines(filename)返回的列表。

 

另:读取文件之后你不需要使用文件的缓存时需要在最后清理一下缓存,使linecache.clearcache()清理缓存,释放缓存。

这个模块是使用内存来缓存你的文件内容,所以需要耗费内存,打开文件的大小和打开速度和你的内存大小有关系。

打印奇数行的文件:

fp='e:\\tmp\\05.txt'
list1=linecache.getlines(fp)
for i in list1[::2]:
print i

 

3、pickle模块和cPickle模块

对文件整体的读写

(1)、pickle模块(Python提供一个标准的模块)

列表内容持久存储到内存中

使用它你可以在一个文件中储存任何Python对象,之后你又可以把它完整无缺地取出来。这被称为持

久地储存对象(序列化)

(2)、cPickle 列表和文件内容的转换

它的功能和pickle模块完全相同,只不过它是用C语言编写的,因此要快得多(比pickle快1000倍),推荐使用。

import cPickle as p

p.dump(list,fp) 把列表list内容保存到内存中,存入一个文件(这个文件带有cPickle特有的格式)中

fp:打开的文件句柄,如:fp=open('d:\\tmp\\test1.txt','wb')

list=p.load(fp) 把之前存放在文件中的内容保存到列表list中

 

 

三、读取文件的位置定位

1、tell()

返回当前操作文件读取到的位置

一个中文:3个字节

Windows下‘\r\n’(换行符)占两个字节,Linux下\n mac下\r.

2、seek(offset[,from]) 移动游标到想去的位置

from:,默认是0,2:从末尾开始计算偏移;1:从当前位置作为标准位置

offset:移动的总距离,可以是正数,可以为负数