python笔记3 - 文件操作
file 对象使用 open 函数来创建,下面说一下对文件的操作分三步:
1、打开文件获取文件的句柄,句柄就理解为这个文件
2、通过文件句柄操作文件,读取/写入文件内容
3、关闭文件。
注意:
文件打开模式有3种:
1. w 写模式,不能读取,只能写入,若文件不存在,则创建
2. r 读模式,不能写入,只能读取,而且文件必须存在;若不传文件打开模式,则默认是 r 读模式
3. a 追加模式,只能写入,在文件末尾添加内容
以w模式打开文件,写入内容,如下:
fp = open('file.txt','w')
fp.write('hhh') #若以w模式打开存在的文件,会清空以前的文件内容,重新写入hhh
以r模式打开文件,读取文件内容,如下:
fp = open('file.txt', 'r', encoding='utf-8') #windows 的默认字符集是gbk,需要设置为utf-8,encoding参数可以指定文件的编码
print(fp.read()) #读取文件内容,返回结果类型是字符串
以r模式打开不存在的文件,如下:
fp = open('a.txt', 'r') #若打开的文件不存在,则报错:FileNotFoundError: [Errno 2] No such file or directory: 'a.txt'
print(fp.read())
以a模式打开不存在的文件,写入内容,如下:
fp = open('a.txt', 'a') #写入不存在的文件名,a追加模式,若文件不存在则创建
fp.write('yiy') #在文件末尾添加内容
以下是文件常用的操作方法:
read()、readline()、readlines() 读取文件内容操作:
fp = open('file.txt', 'a+') #a+模式,指针在文件最后的位置,需要将指针移动到初始文件,才能读取内容
fp.seek(0) #多次读取文件内容时,一定要将游标移动到初始位置,否则读取内容为空
print(fp.read()) #读取文件内容,返回的是字符串,指针移动到最后位置,大文件时不要用,因为会把文件内容都读到内存中,内存不够的话,会把内存撑爆
fp.seek(0) #将指针移动到初始位置
print(fp.readlines()) #读取文件内容,返回的是一个列表,元素是每行的数据,大文件时不要用,因为会把文件内容都读到内存中,内存不够的话,会把内存撑爆
fp.seek(0)
print(fp.readline()) #只读取文件内容的一行内容,返回的是字符串
大文件时,读取文件高效的操作方法:
用上面的read()和readlines()方法操作文件的话,会先把文件所有内容读到内存中,这样的话,内存数据一多,非常卡,高效的操作,就是读一行操作一行,读过的内容就从内存中释放了:
f = open('file.txt')
for line in f:
print(line)
这样的话,line就是每行文件的内容,读完一行的话,就会释放一行的内存
write()、writelines() 写入文件内容操作:
fp = open('file.txt', 'a+')
fp.write(''+'\n') #写文件时,只能写入字符串
fp.writelines(['123\n', '456\n', '']) #writelines可以将列表写入文件
fp.seek(0)
print(fp.readlines()) #执行结果:['2222\n', '123\n', '456\n', '789']
flush()刷新文件内容缓冲,如下:
import time
fp = open('file.txt', 'w') #以w模式打开文件
fp.write('欢乐颂') #写入文件内容
fp.flush() #刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入
time.sleep(30) #sleep时间是30s
fp.close() #关闭文件
tell()查看游标的位置:
fp = open('file.txt', 'r+')
print(fp.read()) #读取文件内容,执行结果:abcdefg
print(fp.tell()) #查看游标所在位置,游标在最后一位
fp.seek(0) #将游标移动到初始位置
print(fp.tell()) #将游标移动到初始位置后,查看游标所在位置
fp.seek(2) #将游标移动到第2位
print(fp.tell()) #将游标移动到初始位置后,查看游标所在位置,游标在第二位
fp.seek(0, 2) #将游标移动到最末尾
print(fp.tell()) #将游标移动到初始位置后,查看游标所在位置,游标在最末尾
truncate(size)截取指定长度的内容:
fp = open('file.txt', 'r+') #file.txt文件内容为abcdefg
print(fp.tell())
#fp.truncate() #若没有指定size,则清空文件内容
fp.truncate(3) #传入size,表示从0开始截断3位字符,其余的清除
fp.seek(0)
print(fp.read()) #执行结果为:abc
with用法,打开文件后,可以不手动关闭,文件不进行操作时,自动关闭,如下:
#with用法 open(文件名) as 别名,默认打开方式是 r模式
with open('file.txt') as fp:
print(fp.read())
使用with打开多个文件,写法如下:
with open('file.txt') as fp, open('a.txt') as fw:
for line in fp:
print(line)
print(fw.readlines())
修改文件的话,有两种方式,一种是把文件的全部内容都读到内存中,然后把原有的文件内容清空,重新写新的内容;第二种是把修改后的文件内容写到一个新的文件中:
第一种:
fp = open('file.txt', 'a+')
fp.seek(0)
res = fp.read() #返回结果类型是字符串,指针在最后面
fp.seek(0) #将指针移动到初始位置
fp.truncate() #清空文件内容
new_res = res.replace('a', 'hello') #将a字符串替换为hello,替换后为新的字符串内容
fp.write(new_res) #将替换后的内容写入文件
第二种:
import os
fp = open('file.txt', 'a+')
fp.seek(0)
fw = open('a.txt', 'w') #打开第二个文件,专门写入替换后的文件内容
for line in fp: #直接循环文件对象,循环的是文件每一行的内容
new_res = line.replace('hello', '') #将hello替换为666,替换后为新的字符串内容
fw.write(new_res) #将修改后的内容写入第二个文件
fp.close() #关闭文件,关闭后不能再进行读写操作
fw.close()
os.remove('file.txt') #删除替换以前的文件
os.replace('a.txt', 'file.txt') #将新文件名替换为已删除的文件名
import os
with open('file.txt') as fp, open('a.txt', 'w') as fw:
for line in fp:
new_res = line.replace('', 'hello')
fw.write(new_res)
os.remove('file.txt')
os.replace('a.txt', 'file.txt')
下表列出了 file 对象常用的函数:
| 序号 | 方法及描述 |
|---|---|
| 1 |
关闭文件。关闭后文件不能再进行读写操作。 |
| 2 |
刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。 |
| 3 |
返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。 |
| 4 |
如果文件连接到一个终端设备返回 True,否则返回 False。 |
| 5 |
返回文件下一行。 |
| 6 |
从文件读取指定的字节数,如果未给定或为负则读取所有。 |
| 7 |
读取整行,包括 "\n" 字符。 |
| 8 |
读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比sizhint较大, 因为需要填充缓冲区。 |
| 9 |
设置文件当前位置 |
| 10 |
返回文件当前位置。 |
| 11 |
截取文件,截取的字节通过size指定,默认为当前文件位置。 |
| 12 |
将字符串写入文件,没有返回值。 |
| 13 |
向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。 |
python笔记3 - 文件操作的更多相关文章
- python笔记:文件操作
1.逐行打印整个文件 # -*- coding: utf-8 -*- f = open("test",'r',encoding="utf-8") count = ...
- python os&shutil 文件操作
python os&shutil 文件操作 # os 模块 os.sep 可以取代操作系统特定的路径分隔符.windows下为 '\\' os.name 字符串指示你正在使用的平台.比如对于W ...
- python 历险记(三)— python 的常用文件操作
目录 前言 文件 什么是文件? 如何在 python 中打开文件? python 文件对象有哪些属性? 如何读文件? read() readline() 如何写文件? 如何操作文件和目录? 强大的 o ...
- Python的高级文件操作(shutil模块)
Python的高级文件操作(shutil模块) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果让我们用python的文件处理来进行文件拷贝,想必很多小伙伴的思路是:使用打开2个 ...
- Python入门篇-文件操作
Python入门篇-文件操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.文件IO常用操作 open:打开 read:读取 write:写入 close:关闭 readlin ...
- python基础篇(文件操作)
Python基础篇(文件操作) 一.初始文件操作 使用python来读写文件是非常简单的操作. 我们使用open()函数来打开一个文件, 获取到文件句柄. 然后通过文件句柄就可以进行各种各样的操作了. ...
- Python之常用文件操作
Python之常用文件操作
- Python之路第一课Day3--随堂笔记(文件操作)
一.集合的介绍 1.集合操作 集合是一个无序的,不重复的数据组合,它的主要作用如下: 去重,把一个列表变成集合,就自动去重了 关系测试,测试两组数据之前的交集.差集.并集等关系 常用操作 s = se ...
- python学习笔记4(文件操作)
文件操作: 1.f=open(”caidan”,”w”,encoding=”utf8”) 直接打开一个文件,如果文件不存在则创建文件 f.close() 2.with open (”caid ...
随机推荐
- Node.js 2017.11.5-2017.11.16期间制作的图片爬虫总结
2017年11月18日12:33:06
- 正则表达式匹配a标签或div标签
这里以a标签为例 a标签的href var a='<P><A href=\'~abc/ccg/ab.jpg\' width="3">文字</A> ...
- iOS项目开发实战——使用CoreLocation获取当前位置信息
随着基于位置服务LBS和移动互联网的兴起,你的位置是越来越重要的一个信息.位置服务已经是当前的热门应用如微信.陌陌等社交应用的杀手锏.而在iOS开发中,苹果已经给我们提供了一个位置接口.CoreLoc ...
- 修改Jenkins的BUILD_NUMBER
因为特殊原因需要修改jenkins的BUILD_NUMBER环境变量,现在将修改方法记录一下, Jenkins ->系统管理->脚本命令行 输入以下脚本,运行就Ok Jenkins.ins ...
- iNode协议再次分析
iNode协议再次分析 声明: 1)本报告由博客园bitpeach撰写,版权所有,免费转载,请注明出处,并请勿作商业用途. 2)若本文档内有侵权文字或图片等内容,请联系作者bitpeach删除相应部分 ...
- ubuntu14.04无法连接有线连接问题
在windows系统下关闭有线网卡的关机,自动唤醒功能即可
- 【java】对数据库操作的那些事(包含数据库中的预处理)
一.连接问题 前面刚介绍了怎么连接数据库,也写了对应的模板.可是它的可维护性很差.那么怎么解决问题呢? 首先写一个配置文件jdbc.properties <span style="fo ...
- 【Python 数据分析】pandas数据导入
导入CSV文件数据 环境 C:\Users\Thinkpad\Desktop\Data\信息表.csv 语法 pd.read_csv(filename):从CSV文件导入数据 实现代码 import ...
- 学习-短信的上行(MO)和下行(MT)详解
基础知识: SP服务提供商: 通常是指在移动网内运营增值业务的社会合作单位, 它们建立与移动网络建立相连的服务平台, 为手机用户提供一系列信息服务, 如:娱乐.游戏.短信.彩信.WAP.彩铃.铃声下载 ...
- struct2常用标签
Struts2常用标签总结 一 介绍 1.Struts2的作用 Struts2标签库提供了主题.模板支持,极大地简化了视图页面的编写,而且,struts2的主题.模板都提供了很好的扩展性.实现了 ...