这一章节主要讲解文件操作及其文件读取,缓存,文件指针。

文件操作

(1)文件打开:open(filepath,filemode)

filepath:要打开文件的路径

filemode:文件打开的方式

mode 说明 注意
'r' 只读方式打开 文件必须存在
'w' 只写方式打开

文件不存在创建文件

文件存在清空内容

'a' 追加方式打开 文件不存在创建文件
'r+'/'w+' 读写方式打开  
'a+' 追加和读写方式打开  

PS:'rb','wb','ab','rb+','wb+','ab+':二进制方式打开

>>> f = open('1.txt','w')
>>> type(f)
<type 'file'>
>>> f.close()

(2)文件写操作:

write(str):将字符串写入文件

writelines(sequence_of_strings):写多行到文件

>>> f = open('1.txt','w+')
>>> f.write("")
>>> f.close()
try:
f = open('1.txt','w')
f.writelines(('','',''))
finally:
if f:
f.close()

(3)文件读操作:

read([size]):读取文件(读取size个字节,默认读取全部)

readline([size]):读取一行

readlines([size]):读取完文件,返回每一行所组成的列表

try:
f = open('1.txt','r')
value = f.read(3)
print value
finally:
if f:
f.close() 122
try:
f = open('1.txt','r')
value = f.readline()
print value
finally:
if f:
f.close() 122345

迭代读取

在实际文件读取中,因为OS缓存是有限的。IO只能缓存8192Byte。

>>> import io
>>> io.DEFAULT_BUFFER_SIZE
8192

如果文件超过8192Byte.直接通过readlines是不能完全读取出来了。

如果要完全读出来,使用迭代读取。

try:
f = open('1.txt','r')
iter_f = iter(f)
lines = 0
for line in iter_f:
lines+=1
print line
print lines
finally:
if f:
f.close() #1.txt有7行数据,使用迭代方式iter来将f对象迭代。
122345 1223456 12234567 122345678 1223456789 12234567890 122345678901
7

缓存机制

上一节讲到迭代读取,大家知道IO缓存最大为8192.对于IO操作来讲,缓存指的是内存缓存数据,执行之后,再从缓存写入到硬盘。

针对于IO文件write操作来讲,每次我们写入数据的时候,都是先写入缓存,执行close或者flush之后,才会真正的将缓存写入到硬盘。

所以,务必在操作完文件之后,必须最后执行f.close或者中途执行f.flush的动作。

文件指针

看下下面的例子:

try:
f = open('1.txt','r+')
dat = f.read(3)
print dat
dat = f.read(3)
print dat
finally:
if f:
f.close() 122
345

大家通过这个例子可以发现,read操作读取数据之后,再次调用读取操作,是不会从开始字节读取。这个就牵扯到文件指针的概念。

当f.read(3),文件指针就移动到第三个字节位置,当再次调用f.read(3),同样文件指针就移动到第六个字节位置。如果想要回滚会文件首部字节读取怎么办?

使用f.seek操作,先来看看seek函数的介绍:(偏移量超出文件长度就会报错)

f.seek(0, os.SEEK_SET) #移动文件指针到文件起始位置
f.seek(0, os.SEEK_END) #移动文件指针到文件末尾位置
f.seek(5, os.SEEK_CUR) #移动文件指针到当前位置的前5个字节上
f.seek(-5, os.SEEK_CUR)#移动文件指针到从文件末尾起前5个字节

try:
f = open('1.txt','r+')
dat = f.read(3)
location = f.tell()
print "location :%s" % location#标识当前文件指针的位置
print dat
dat = f.read(3)
location = f.tell()
print "location :%s" % location#标识当前文件指针的位置
print dat
finally:
if f:
f.close() location :3 #标识当前文件指针的位置
122
location :6
345
try:
f = open('1.txt','r+')
dat = f.read(3)
location = f.tell()
print "location :%s" % location
print dat
f.seek(os.SEEK_SET)#调用seek的动作
location = f.tell()
print "location :%s" % location
dat = f.read(3)
location = f.tell()
print "location :%s" % location
print dat
finally:
if f:
f.close() location :3
122
location :0
location :3
122

通过上述例子可以看出,seek动作可以将文件指针重新回到文件首部。文件指针的位置可以通过f.tell()方法知道。seek其他参数讲解大家一一去尝试操作下。

文件编码格式

try:
f = open('1.txt','r+')
f.write('qwer')
f.write(u'博客园')
finally:
if f:
f.close() Traceback (most recent call last):
File "<pyshell#69>", line 4, in <module>
f.write(u'博客园')
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-2: ordinal not in range(128)

大家都知道,有时候需要在文档里面写中文。上面的写法会直接报错。那么如何写入unicode编码的字符呢?

提供两种方法:

1、直接将unicode编码字符转换为utf8编码字符保存 :unicode.encode(u'博客园','utf-8')

try:
f = open('1.txt','r+')
f.write('qwer')
val = unicode.encode(u'博客园','utf-8')
f.write(val)
finally:
if f:
f.close() >>> try:
f = open('1.txt','r+')
w = f.read()
print w
finally:
if f:
f.close() qwer博客园56

2.使用codecs模块直接创建指定编码格式的文件

>>> import codecs
>>> help(codecs.open)
Help on function open in module codecs: open(filename, mode='rb', encoding=None, errors='strict', buffering=1).....

那我们用了实例试试:

try:
f = codecs.open('5.txt','w+','utf-8')
f.write(u'博客园')
f.flush()
finally:
if f:
f.close()

小结:这一章节主要讲解python的文件操作及其文件编码。

												

python学习第十八天 --文件操作的更多相关文章

  1. Python学习:7.文件操作

    文件操作 我们曾将听过一个问题,将大象放入冰箱分为三步:1.打开冰箱门,2.将大象放进去,3.关上冰箱门.今天我们要讲的Python文件操作的步骤就像将大象放入冰箱的步骤一样. 使用Python操作文 ...

  2. 【Python学习之六】文件操作

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 python3.6 一.文件的打开与关闭 使用open函数,可以打开一 ...

  3. python学习笔记之文件操作(三)

    这篇博客小波主要介绍一下python对文件的操作 对文件的操作主要分为三步: 1.打开文件获取文件的句柄,句柄也是文件描述符 2.通过文件句柄操作文件 3.关闭文件. 现有以下文件,是小波随写的周杰伦 ...

  4. python学习笔记4(文件操作)

    文件操作: 1.f=open(”caidan”,”w”,encoding=”utf8”)      直接打开一个文件,如果文件不存在则创建文件 f.close() 2.with open (”caid ...

  5. python学习笔记三 文件操作(基础篇)

    文件操作 打开文件 open(name[,mode[,buffering]])   open函数使用一个文件名作为强制参数,然后返回一个文件对象.[python 3.5 把file()删除掉]   w ...

  6. python学习笔记(三):文件操作和集合

    对文件的操作分三步: 1.打开文件获取文件的句柄,句柄就理解为这个文件 2.通过文件句柄操作文件 3.关闭文件. 文件基本操作: f = open('file.txt','r') #以只读方式打开一个 ...

  7. Python学习之路——文件操作

    文件操作分三步:打开文件,读写文件,关闭文件.读取操作时没有给read函数加括号,会出现下面这样的车祸 >>> data = open('/home/supersun/Documen ...

  8. Python学习笔记 - day5 - 文件操作

    Python文件操作 读写文件是最常见的IO操作,在磁盘上读写文件的功能都是由操作系统提供的,操作系统不允许普通的程序直接操作磁盘(大部分程序都需要间接的通过操作系统来完成对硬件的操作),所以,读写文 ...

  9. Python学习系列之文件操作

    Pyhton文件打开方式 with= open('文件路径','打开模式') as f:#PS:python3提供了with语句来帮我们自动调用close方法,所以说无论打开文件是否出错都能自动正确的 ...

随机推荐

  1. Censored! - POJ 1625(ac自动机+简单dp+高精度运算)

    题目大意:首先给一个字符集合,这个集合有N个字符,然后需要一个长度为M的句子,但是据子里面不能包含的串有P个,每个串里面的字符都是有字符集和里面的字符构成的,现在想知道最多能构造多少个不重复的句子. ...

  2. DNA Sequence - POJ 2778(AC自动机+矩阵乘法)

    题目大意:DNA序列是有 ATGC 组成的,现在知道一些动物的遗传片段有害的,那么如果给出这些有害的片段,能否求出来所有长度为 N 的基因中有多少是不包含这些有害片段的.   分析:也是断断续续做了一 ...

  3. springmvc框架原理分析

    第一步:用户发起请求到前端控制器(DispatcherServlet) 第二步:前端控制器请求HandlerMapping查找Handler,可以根据xml配置,注解进行查找 第三步:处理器映射器Ha ...

  4. Python里的map、reduce、filter、lambda、列表推导式

    Map函数: 原型:map(function, sequence),作用是将一个列表映射到另一个列表, 使用方法: def f(x): return x**2 l = range(1,10) map( ...

  5. JSP基本语法

    在tomcat环境搭建一文中为大家详细的介绍了第一个JSP的程序--Hello World,大家都应该顺利的完成了吧,以此为一个开端,希望大家在学习java EE的路上乘风破浪,不断进步.今天,为大家 ...

  6. 【Java规划】DOM XML Parser分解、遍历、创XML

    1.前言 DOM XML Parser简介 DOM 它是 W3C 处理 XML 规范 API,这是很多其他的 XML 地基处理相关标准,不仅是 Java,其他的,如 Javascript,PHP.MS ...

  7. jquery中修改一个元素的值或内容

    jquery中修改一个元素的值或内容,比如数值增加可以使用这个方法取得原值并+1 $this.text(function(i,ot){return Number(ot)+1;});

  8. Java多态性举例说明

    Java多态性的概念也可以被说成“一个接口,多个方法”. (一)相关类 class A ...{ public String show(D obj)...{ return ("A and D ...

  9. Handler导致内存泄露分析

    (非静态)内部类引起内存泄漏的原因         内部类的实现其实是通过编译器的语法糖(Syntactic sugar)实现的,通过生成相应的子类即以OutClassName$InteriorCla ...

  10. xUtils3源码分析(一):view的绑定

    概述 xUtils3是国人开发的一款功能丰富的Android快速开发框架,值得研究下.zip包下载:[ZIP]xutils主要分以下几个模块 视图绑定模块 网络请求模块 数据库模块 图片加载模块 我们 ...