1.创建文件

>>> file('test.txt','w')   -->在当前路径下创建文件

test.txt是文件名

w是打开文件的方式,r是读,w是写,a是追加,如果当前路径没有这个文件,用w可以直接创建

2.往文件中写内容

>>> file('test.txt','w').write('hello')  #如果是以'w'模式打开的,那么会重新写这个test.txt文件,原来的内容不再有。

正确的写法:

>>> f = file('test.txt','w')

>>> f.write('hello\n')    #\n 是换行

>>> f.write('hello2')  #现在写的数据还在内存里边,没有写到硬盘上,此时查看文件是空的,即便原来有数据。

>>> f.close() #把文件关掉就写到硬盘上了,只要是用w模式打开的写数据,就会覆盖掉以前的数据,产生一个新文件

3.读文件

如果是以w模式打开文件的,写完数据之后不想关闭文件,但是还想看到文件中的内容,用flush(),但是这样会报错,因为你用的是w模式打开的,所以没法读取,在这儿只是想引进flus()的使用方法

不写打开文件模式,默认是以r来打开文件的

>>> f = file('test.txt')
>>> f.read()   #read()方法读取出来的是字符串,全部读取出来
'hellohello\n'

>>> f.readline()   #这个是读取文件一行的方法,在这儿为什么会是空的呢?因为在刚打开文件时,我们用f.read()读取了一次,相当于从内存中把这个字符串全部读取了出来,
''             #这时候指针就移到了字符串的后边,那同时也就没有了内容。

可以通过这个来验证以上内容是否正确

>>> f = file('test.txt')   #关闭文件后重新打开
>>> f.tell()        #查看文件内容在内存指针的位置
0             #结果是0,也就是没读取文件之前指针在最前边
>>> f.readline()    #读取test.txt中的一行
'hello\n'        #显示结果以字符串的形式出现
>>> f.readline()
'hello\n'        #test.txt总共写了两行hello
>>> f.readline()    #在读取的时候就没有内容了,因为第三行没有内容,所以显示空
''
>>> f.tell()      #再次调用查看指针在内存中的位置
12
>>>

>>>f.seek(0)      #将指针移到0位置上,就可以重新读取内容了

>>> f.tell()

0

>>> f.seek(0)

>>> f.readines() #以列表的方式读取出来,然后可以精确的拿出第几行,但是是读到内存中去的,占用内存空间,文件太大的时候会卡

f.xreadlines() #是读取文件所有行的迭代器,如果一个G的日志文件,用这种方法比直接用readline()要快,因为readline()这个方法是先读到内存在打印,所以在打印1G的日志文件时会先等一会儿才会打印,而xreadline()会直接打印,内存中读一行然后扔一行

4.遍历文件,两种遍历方法。

#!/usr/bin/env python
f = file('auth.log')
for line in f.xreadlines():
    print line,

#!/usr/bin/env python
while True:
     line = f.readline()
     print line,
     if not line:break

5.读取文件的模式

如果文件以读写模式打开('r+'),那么写的时候是根据指针的位置来覆盖文件的,如果先读了一行,在往文件写的时候,会覆盖第二行的字符,而不是整个第二行!

('rb')可以处理二进制文件。如果windows过来的python文件,在linux上处理的时候用这个二进制文件处理。换平台的时候有时候会报错。

6.文件内容替换,批量更改文件

for line in fileinput.input("filepath",inplace=1):   #inplace=1 表示文件里的内容也同时改掉,如果是0的话,文件里的内容不会改掉,只是会打印出来。

line = line.replace("oldtext","newtext")

print line,   #必须print,没有print更改失败!

backup=''  #修改文件之前做备份,只需要加个后缀即可

#!/usr/bin/env python
import fileinput
for line in fileinput.input("test.txt",inplace=1,backup='.bak'):
line = line.replace("hello2222","hello2")
print line,

备份的文件没有被修改,test.txt.bak就是备份的文件

7.存放不同类型的文件到同一个文件中,以二进制存储

#!/use/bin/env python

improt struct

n=1600    整数类型

x=92.60   浮点型

b=True    bool型

s='!@中国'   字符串型

sn=struct.pack('if?',n,x,b)   将不同类型转换成二进制方法

f=open('erjinzhi.dat','wb')

f.write(sn)

f.write(s)

f.close

python文件处理复习的更多相关文章

  1. 课程 python 文件操作复习

    # 文件处理 # 打开文件 #open('路径','打开方式','指定编码方式') # 打开方式 r w a r+ w+ a+ b #r+ 打开文件直接写 和读完再写 # 编码方式 —— utf-8 ...

  2. Linux下Python 文件内容替换脚本

    Linux下Python 文件替换脚本 import sys,os if len(sys.argv)<=4: old_text,new_text = sys.argv[1],sys.argv[2 ...

  3. 【Python文件处理】递归批处理文件夹子目录内所有txt数据

    因为有个需求,需要处理文件夹内所有txt文件,将txt里面的数据筛选,重新存储. 虽然手工可以做,但想到了python一直主张的是自动化测试,就想试着写一个自动化处理数据的程序. 一.分析数据格式 需 ...

  4. Python文件使用“wb”方式打开,写入内容

    Python文件使用"wb"方式打开,写入字符串会报错,因为这种打开方式为:以二进制格式打开一个文件只用于写入.如果该文件已存在则将其覆盖.如果该文件不存在,创建新文件. 所以写入 ...

  5. Python 文件操作函数

    这个博客是 Building powerful image classification models using very little data 的前期准备,用于把图片数据按照教程指示放到规定的文 ...

  6. python文件I/O(转)

    Python 文件I/O 本章只讲述所有基本的的I/O函数,更多函数请参考Python标准文档. 打印到屏幕 最简单的输出方法是用print语句,你可以给它传递零个或多个用逗号隔开的表达式.此函数把你 ...

  7. python 文件操作总结

    Python 文件I/O 本章只讲述所有基本的的I/O函数,更多函数请参考Python标准文档. 打印到屏幕 最简单的输出方法是用print语句,你可以给它传递零个或多个用逗号隔开的表达式.此函数把你 ...

  8. Python基础篇【第2篇】: Python文件操作

    Python文件操作 在Python中一个文件,就是一个操作对象,通过不同属性即可对文件进行各种操作.Python中提供了许多的内置函数和方法能够对文件进行基本操作. Python对文件的操作概括来说 ...

  9. python文件和元组

    python文件操作 相较于java,Python里的文件操作简单了很多 python 获取当前文件所在的文件夹: os.path.dirname(__file__) 写了一个工具类,用来在当前文件夹 ...

随机推荐

  1. unity中让摄像机移动到鼠标点击的位置和鼠标控制平移视角

    private Vector3 targetVector3; private float movespeed=0.5f; private bool IsOver = true; private Gam ...

  2. dgango中admin下添加搜索功能

    admin下添加搜索功能: 在表单中加入search_fields = ['ip','hostname']   可模糊匹配 当有人在管理搜索框中进行搜索时,Django将搜索查询分解成单词,并返回包含 ...

  3. day18 类与类之间的关系

    今日所学内容: 1.类与类之间的关系 2.self 到底是谁? 3. 特殊成员 : 1.类与类之间的关系 在我们的世界中事物和事物之前总会有一些联系 在面向对象中,类与类之间也可以产生相关的联系 1) ...

  4. :适配器模式:Adapter

    #ifndef __ADAPTER_H__ #define __ADAPTER_H__ #include <iostream> using namespace std; class Duc ...

  5. `define、parameter、localparam三者的区别(转)

    `define: 可以跨模块的定义,写在模块名称上面,在整个设计工程都有效.一旦‘define指令被编译,其在整个编译过程中都有效.例如,通过另一个文件中的`define指令,定义的常量可以被其他文件 ...

  6. http响应头

    If-Modified-Since标签,下图可以看出requestHeader中有If-Modified-Since

  7. JDK的下载及配置

    下载地址,为了兼容最好安装1.8版本 jdk1.8:http://jbox.jd.com/quickshare/d2wheyazjtdccshou2dbo24roejdk1.7:http://jbox ...

  8. [Spring] Spirng中的AOP进行事务的传播属性和事务隔离级别

    通知注解 前置通知(@Before):在某连接点(join point)之前执行的通知,但这个通知不能阻止连接点前的执行(除非它抛出一个异常) 返回后通知(@AfterReturning):在某连接点 ...

  9. Hibernate总结以及在面试中的一些问题.

    Hibernate总结以及在面试中的一些问题.   1.为什么要使用Hibernate开发你的项目呢?Hibernate的开发流程是怎么样的? 为什么要使用 ①.对JDBC访问数据库的代码做了封装,大 ...

  10. [转]Cross-type joins in Elasticsearch

    Cross-type joins in Elasticsearch http://rore.im/posts/elasticsearch-joins December 31, 2014 When mo ...