详解Python中的文件操作
作者:daisy 发布时间:2022-08-26 03:35:18
1.能调用方法的一定是对象,比如数值、字符串、列表、元组、字典,甚至文件也是对象,Python中一切皆为对象。
str1 = 'hello'
str2 = 'world'
str3 = ' '.join([str1,str2])
print(str3)
2.三种基本的文件操作模式:r(only-read)、w(only-write)、a(append)
对文件进行操作的流程:
第一,建立文件对象。
第二,调用文件方法进行操作。
第三,不要忘了关闭文件。(文件不关闭的情况下,内容会放在缓存,虽然Python会在最后自动把内容读到磁盘,但为了以防万一,要养成关闭文件的习惯)
文件file1
一张褪色的照片,
好像带给我一点点怀念。
巷尾老爷爷卖的热汤面,
味道弥漫过旧旧的后院;
流浪猫睡熟在摇晃秋千,
夕阳照了一遍他咪着眼;
那张同桌寄的明信片,
安静的躺在课桌的里面。
(1)r模式
在只读模式下写入内容会报错。
f = open('file1','r')
f_read = f.read() #read是逐字符地读取,read可以指定参数,设定需要读取多少字符,无论一个英文字母还是一个汉字都是一个字符。
print(f_read)
f.close()
f = open('file1','r')
f_read = f.readline() #readline只能读取第一行代码,原理是读取到第一个换行符就停止。
print(f_read)
f.close()
f = open('file1','r')
f_read = f.readlines() #readlines会把内容以列表的形式输出。
print(f_read)
f.close()
f = open('file1','r')
for line in f.readlines() #使用for循环可以把内容按字符串输出。
print(line) #输出一行内容输出一个空行,一行内容一行空格... 因为文件中每行内容后面都有一个换行符,而且print()语句本身就可以换行,如果不想输出空行,就需要使用下面的语句:print(line.strip())
f.close()
(2)w模式
在进行操作前,文件中所有内容会被清空。比如在file1中写入'hello world',程序执行后file1中就只剩下一句'hello world'
f = open('file1','w',encoding='utf8') #由于Python3的默认编码方式是Unicode,所以在写入文件的时候需要调用utf8,以utf8的方式保存,这时pycharm(默认编码方式是utf8)才能正确读取,当读取文件时,文件是utf8格式,pycharm也是utf8,就不需要调用了。
f_w = f.write('hello world')
print(f_w) #有意思的是,这里并不打印'hello world',只打印写入多少字符
f.close()
(3)a模式
与w模式不同的是,a模式不会把原来内容清空,而是光标移到内容最后位置,继续写入新内容。比如在最后追加'hello world'
f = open('file1','a')
f_a = f.write('hello world')
print(f_a) #还是会打印写入的字符数
f.close()
打印文件,在'流浪猫睡熟在摇晃秋千'后面加上'helloworld'输出
在r模式时,我们说过用for
循环和readlines()
输出文件内容,这种输出内容的原理是:打开文件,把全部内容读入内存,然后再打印输入,当文件很大时,这种读取方式就不靠谱了,甚至会使机器崩溃。我们需要及时关闭文件,如下:
f = open('file','r')
data=f.readlines() #注意及时关闭文件
f.close()
num = 0
for i in data:
num += 1
if num == 5:
i = ''.join([i.strip(),'hello world']) #不要使用“+”进行拼接
print(i.strip())
f.close()
对于大数据文件,要使用下面的方法:
num = 0
f.close() #不要过早关闭文件,否则程序不能识别操作句柄f.
f = open('file','r')
for i in f: #for内部把f变为一个迭代器,用一行取一行。
num += 1
if num == 5:
i = ''.join([i.strip(),'hello world'])
print(i.strip())
f.close()
3.tell和seek
tell:查询文件中光标位置
seek:光标定位
f = open('file','r')
print(f.tell()) #光标默认在起始位置
f.seek(10) #把光标定位到第10个字符之后
print(f.tell()) #输出10
f.close()
----------------------
f = open('file','w')
print(f.tell()) #先清空内容,光标回到0位置
f.seek(10)
print(f.tell())
f.close()
----------------------
f = open('file','a')
print(f.tell()) #光标默认在最后位置
f.write('你好 世界')
print(f.tell()) #光标向后9个字符,仍在最后位置
f.close()
4.flush 同步将数据从缓存转移到磁盘
示例,实现进度条功能
import sys,time #导入sys和time模块
for i in range(40):
sys.stdout.write('*')
sys.stdout.flush() #flush的作用相当于照相,拍一张冲洗一张
time.sleep(0.2)
下面代码也能够实现相同的功能
import time
for i in range(40):
print('*',end='',flush=True) #print中的flush参数
time.sleep(0.2)
5.truncate 截断
不能是r模式下执行,
w模式下,已经清空所有数据,使用truncate
没有任何意义,
a模式下,截断指定位置后的内容。
f = open('file','a')
f.truncate(6) #只显示6个字节的内容(6个英文字符或三个汉字),后面的内容被清空。
6.光标位置总结
一个汉字两个字节,涉及光标位置的方法有4个:read
、tell
、seek
、truncate
。
#--------------------------光标总结head-----------------------------------
f = open('file','r')
print(f.read(6)) #6个字符
print(f.tell()) #位置12字节,一个汉字两个字节
f.close()
f = open('file','r')
f.seek(6) #6个字节
print(f.tell())
f.close()
f = open('file','a')
print(f.tell()) #光标默认在最后位置
f.write('你好 世界')
print(f.tell()) #光标向后9个字节,一个汉字两个字节,仍在最后位置 182-->191
f.close()
f = open('file','a',encoding='utf-8')
print(f.truncate(6)) #由于需要光标定位位置,所以也是字节。只显示6个字节的内容(6个英文字母或三个汉字,一个汉字两个字节),后面的内容被清空。
f.close()
#-----------------------------光标总结end---------------------------------
7.另外3种模式:r+、w+、a+
r+:读写模式,光标默认在起始位置,当需要写入的时候,光标自动移到最后
w+:写读模式,先清空原内容,再写入,也能够读取
a+:追加读模式,光标默认在最后位置,直接写入,也能够读取。
f = open('file','a')
print(f.tell()) #末尾207位置
f.close()
f = open('file','r+')
print(f.tell()) #0位置
print(f.readline()) #读取第一行
f.write('羊小羚') #光标移到末尾207位置并写入
print(f.tell()) #213位置
f.seek(0) #光标移到0位置
print(f.readline()) #读取第一行
f.close()
8.修改文件内容
思路:由于数据存储机制的关系,我们只能把文件1中的内容读取出来,经过修改后,放到文件2中。
f2 = open('file2','w',encoding='utf8') #写入的时候必须加utf8
f1 = open('file','r')
num = 0
for line in f1: #迭代器
num += 1
if num == 5:
line = ''.join([line.strip(),'羊小羚\n']) #里面就是对字符串进行操作了
f2.write(line)
f1.close()
f2.close()
9.with语句
可以同时对多个文件同时操作,当with
代码块执行完毕时,会自动关闭文件释放内存资源,不用特意加f.close()
,我们通过下面的示例体会with
的用法和好处。
用with
语句重写8中的代码
num = 0
with open('file','r') as f1,open('file2','w',encoding='utf8') as f2:
for line in f1:
num += 1
if num == 5:
line = ''.join([line.strip(),'羊小羚'])
f2.write(line)
10.总结
猜你喜欢
- 我们大家都知道CSS功能的强大,而有关CSS基本的排版控制虽然已有详细的使用说明和参考教程,但还有许多丰富的CSS排版能力,是很少能查到的。
- 一、说明早上看到Python使用pickle进行序列化和反序列化,然后发现面临的一个获取不到返回值的框架,似乎可以通过在框架中先序列化,然后
- 基于pygame的飞机大作战小游戏,适合新手,不能直接运行,只能在命令行进入当前游戏目录,输入python game.py才能够运行,尚不知
- 1. 带默认值的参数在了解带星号(*)的参数之前,先看下带有默认值的参数,函数定义如下:>> def defaultValueA
- 直接转换就行了,key为DataFrame的column;import pandas as pddata = pd.read_csv(
- 一.设置客户端网络实用工具点击“开始”-“程序”,在“Microsoft SQL Server”菜单中选择“客户端网络实用工具”。在“别名”
- import介绍import语句作用就是用来导入模块的,它可以出现在程序中的任何位置。import语句语法使用import语句导入模块,im
- 如果能,请问如何实现 谢谢set aa=server.cre
- 茎叶图from itertools import groupbynums2=[225, 232,232,245,235,245,270,22
- 在Python语言中,json数据与dict字典以及对象之间的转化,是必不可少的操作。在Python中自带json库。通过import js
- 译者按:我们时常能看到不同JavaScript库/框架之间的各种比较,但这次 YUI3 架构师和 jQuery 之父的直接对话却非常难得,也
- 本文实例讲述了Python使用正则表达式过滤或替换HTML标签的方法。分享给大家供大家参考,具体如下:python正则表达式关键内容:pyt
- adodb.stream对象的方法/属性cancel 方法使用方法如下object.cancel说明:取消执行挂起的异步 execute 或
- 前言近几日迫于被辅导员三番五次的提醒每日一报打卡,就想着去写个脚本挂在服务器上定时执行。经过我不懈的努力,最终选择了seleniumsele
- 介绍据官方所述,mango Cache是对Guava Cache基于go的部分实现,同时mangoCache参考了Caffeine以及go-
- meta是html语言head区的一个辅助性标签。几乎所有的网页里,我们可以看到类似下面这段的html代码:<head> <meta&nbs
- 异常捕捉:try: XXXXX1 raise Exception(“xxxxx2”) except (Except
- 登录百度,首先当然是先抓百度的登录包 ,由于是网页登录,最方便的自然是httpwatch了,我使用的测试账号是itiandatest1,密码
- 这里我不想采用诸如ubuntu下的apt-get install方式进行python的安装,而是在linux下采用源码包的方式进行pytho
- 1. 引言在本文中,我们将研究从列表中选择随机元素的不同实现方法。在日常项目中,我们经常会遇到这种情形,比如随机从多种数据增强策略中选择一种