Python读写文件

 

Python中文件操作可以通过open函数,这的确很像C语言中的fopen。通过open函数获取一个file object,然后调用read(),write()等方法对文件进行读写操作。

1.open

使用open打开文件后一定要记得调用文件对象的close()方法。比如可以用try/finally语句来确保最后能关闭文件。

file_object  =  open( ' thefile.txt ' )
try :
    all_the_text 
=  file_object.read( )
finally :
    file_object.close( )


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

2.读文件

读文本文件
input  =  open( ' data ' ' r ' )
# 第二个参数默认为r
input  =  open( ' data ' )

 

读二进制文件: 打开二进制文件要加'b'标记
input  =  open( ' data ' ' rb ' )

 

读取所有内容
file_object  =  open( ' thefile.txt ' )
try :
    all_the_text 
=  file_object.read( )
finally :
    file_object.close( )

 

读固定字节
file_object  =  open( ' abinfile ' ' rb ' )
try :
    
while  True:
        chunk 
=  file_object.read( 100 )
        
if   not  chunk:
            
break
        do_something_with(chunk)
finally :
    file_object.close( )

 

读每行
list_of_all_the_lines  =  file_object.readlines( )


如果文件是文本文件,还可以直接遍历文件对象获取每行:

for  line  in  file_object:
    process line

 

3.写文件

写文本文件
output  =  open( ' data ' ' w ' )

 

写二进制文件
output  =  open( ' data ' ' wb ' )

 

追加写文件
output  =  open( ' data ' ' w+ ' )

 

写数据
file_object  =  open( ' thefile.txt ' ' w ' )
file_object.write(all_the_text)
file_object.close( )

 

写入多行
file_object.writelines(list_of_text_strings)


注意,调用writelines写入多行在性能上会比使用write一次性写入要高。

 

 

 

在解析一个二进制文件的时候,想把读取的单个的byte转换为python的char类型值

f = file(...)
buf = f.read(1024)
int(buf[0])

结果总是报错:ValueError: invalid literal for int() with base 10: ‘/x90′


这里找到了对这个问题的解释和解决的办法


在python中,file.read 得到的结果是string, 要转换成别的类型,需要用到struct, struct就是为了读写2进制文件弄出来的东西。

import struct
...
value = struct.unpack(fmt, buf[0])[0]

关于 struct.unpack 的用法,可以参考这个链接,其中有 fmt 的详细的说明。


举例来讲,如果是想转换成unsigned char,就用:

uchar = struct.unpack('B', buf[0])[0]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值