从0开始学python:打开编辑文件

来源:互联网 发布:h3c mac地址绑定ip 编辑:程序博客网 时间:2024/06/05 13:33
Python的open方法用来打开一个文件。第一个参数是文件的位置和文件名,第二个参数是读写模式;


f=open('test.txt','w')
读写模式的类型有:
以读方式打开, 同时提供通用换行符支持
w     以写方式打开,
a     以追加模式打开 (从 EOF 开始, 必要时创建新文件)
r+     以读写模式打开
w+     以读写模式打开 (参见 w )
a+     以读写模式打开 (参见 a )
rb     以二进制读模式打开
wb     以二进制写模式打开 (参见 w )
ab     以二进制追加模式打开 (参见 a )
rb+    以二进制读写模式打开 (参见 r+ )
wb+    以二进制读写模式打开 (参见 w+ )
ab+    以二进制读写模式打开 (参见 a+ )
a.     Python 2.3 中新增


注意:
1、使用'W',文件若存在,首先要清空,然后(重新)创建,


2、使用'a'模式 ,把所有要写入文件的数据都追加到文件的末尾,即使你使用了seek()指向文件的其他地方,如果文件不存在,将自动被创建。


3、使用open打开文件后一定要记得关闭文件对象,f.close()。可以用try/finally语句来确保最后能关闭文件。
file_object= open('thefile.txt')
try:
all_the_text = file_object.read( )
finally:
file_object.close( )


注:不能把open语句放在try块里,因为当打开文件出现异常时,文件对象file_object无法执行close()方法。


向文件添加内容

在open的时候制定'a'即为(append)模式,在这种模式下,文件的原有内容不会消失,新写入的内容会自动被添加到文件的末尾。

#to appendtestFile = open('cainiao.txt','a')testFile.write('\n\n')testFile.close()  

读文件内容

在open的时候制定'r'即为读取模式,使用

#to readtestFile = open('cainiao.txt','r')testStr = testFile.readline()print testStrtestStr = testFile.read()print testStrtestFile.close()  

在文件中存储和恢复Python对象

使用Python的pickle模块,可以将Python对象直接存储在文件中,并且可以再以后需要的时候重新恢复到内容中。

testFile = open('pickle.txt','w')#and import pickleimport pickletestDict = {'name':'Chen  Zhe','gender':'male'}pickle.dump(testDict,testFile)testFile.close()testFile = open('pickle.txt','r')print pickle.load(testFile)testFile.close()  

二进制模式

调用open函数的时候,在模式的字符串中使用添加一个b即为二进制模式。

#binary modetestFile = open('cainiao.txt','wb')#where wb means write and in binaryimport structbytes =  struct.pack('>i4sh',100,'string',250)testFile.write(bytes)testFile.close()

读取二进制文件。

testFile = open('cainiao.txt','rb')data = testFile.read()values = struct.unpack('>i4sh',data)print values


打开文件后,读文件的方法:


我们谈到“文本处理”时,我们通常是指处理的内容。Python 将文本文件的内容读入可以操作的字符串变量非常容易。文件对象提供了三个“读”方法: .read()、.readline() 和 .readlines()。每种方法可以接受一个变量以限制每次读取的数据量,但它们通常不使用变量。 .read() 每次读取整个文件,它通常用于将文件内容放到一个字符串变量中。然而 .read() 生成文件内容最直接的字符串表示,但对于连续的面向行的处理,它却是不必要的,并且如果文件大于可用内存,则不可能实现这种处理。

.readline() 和 .readlines() 非常相似。它们都在类似于以下的结构中使用:

Python .readlines() 示例

        fh = open( 'c:\\autoexec.bat')         for line in fh.readlines():                     print   line.readline() 和 .readlines()之间的差异是后者一次读取整个文件,象 .read()一样。.readlines()自动将文件内容分析成一个行的列表,该列表可以由 Python 的 for... in ... 结构进行处理。另一方面,.readline()每次只读取一行,通常比 .readlines()慢得多。仅当没有足够内存可以一次读取整个文件时,才应该使用.readline()。   

写:

  writeline()是输出后换行,下次写会在下一行写。write()是输出后光标在行末不会换行,下次写会接着这行写


原创粉丝点击