python中对文件操作有哪些?怎样实现?
Admin 2021-08-21 群英技术资讯 1227 次浏览
这篇文章主要给大家分享python中对文件的操作,包括文件的打开和关系,读写文件和文件备案,对新手学习Python有一定的借鉴价值,感兴趣的朋友可以参考一下,希望大家阅读完这篇文章能有所收获,下面我们一起来学习一下吧。
f=open('text.txt','w')#创建text.txt文件,用f来指代
f.close()#关闭文件
注意: 打开一个文件之后,一定要关闭,否则后面无法继续操作这个文件
with 上下文管理,不管在处理文件过程中是否发生异常,都能保证 with 语句执行完毕后已经关闭打开的文件句柄。
def main():
with open('text.txt','w+') as f:
content=f.read()#读取文件写入内容
print(content)#输出
main()#输出完成后会自动关闭文件
错误:如果报错io.UnsupportedOperation: not readable
因为你是用open打开一个文件,此时调用的是w写入模式,下面使用read是没有权限的,你得使用w+读写模式

写文件 write默认的编码是gbk 这个是中文编码,最好的习惯呢就是我们再打开一个文件的时候给它指定一个编码类型encoding,要不然会出现乱码
f=open('text.txt','w',encoding='utf-8')#w为写入模式
f.write('人生苦短,我用python')#写入文件text.txt
f.close()
#writelines()可传一个可迭代对象
f=open('text.txt','a',encoding='utf-8')#a为追加模式
他会自动生成text文件然后写入

writelines 方法将可迭代对象,迭代写入文件
f.write('\r\n')
f.writelines(['人生','就是','不断的学习'])
print('\n')
f.close()

read(num):传入一个数字做参数,表示读取指定字符个数。列:read(1)
readlines() :按行读取,一次性读取所有内容,返回一个列表,每一行内容作为一个元素。
readline() :按行读取,但是一次只读取一行。
#读取文件
f=open('text.txt','r',encoding='utf-8')#只读模式
print(f.read())#全部读取输出
f.close()
注意:出现UnicodeDecodeError: ‘gbk' codec can't decode byte 0xad in position 52: illegal multibyte sequence错误
解决:open中加入encoding=‘utf-8'就行
利用脚本完成自动备份,要求用户输入文件名称,完成自动备份
def copyfile():
#接收输入的文件
old_file=input('请输入要备份的文件:')
file_list=old_file.split(".")#split()函数通过指定分隔符对字符串进行切片,假设要备份text.txt文件,输出是['text', 'txt']
new_file=file_list[0]+'_备份.'+file_list[1]#构造新的文件名,加上备份后缀
old_f=open(old_file,'r')#只读模式打开备份的文件
new_f=open(new_file,'w')#只写模式打开新文件,不存在则创建
new_f.write(old_f.read())#将备份文件内容读取出来写入新文件
#关闭所有打开文件
old_f.close()
new_f.close()
copyfile()#到时候文件夹里面会出现一个text_备份.txt的文件,内容和备份文件一样

如果处理超大文件,一次将全部内容读取出来显然是不合适的,在上面代码的基础上改进下代码,让它备份大文件也不会导致内存被占满。
def copyfile2():
#接收输入的文件
old_file=input('输入要备份的文件')
#如果没有输入或者输入错误就提示
if not old_file:
print('输入错误')
old_file = input('输入要备份的文件:')
else:
file_list=old_file.split(".")
print(file_list)
#创造新的文件名,加上备份后缀
if len(file_list)<2:#如果列表长度小于2,就不用加.
new_file=file_list[0]+'_备份2'
pass
else:#文件有后缀的情况
new_file=file_list[0]+'_备份2.'+file_list[1]
#用异常处理判断内存是否被占满
try:
#同时打开需要备份的文件,新文件
with open(old_file,'r') as old_f, open(new_file,'a') as new_f:
while True:
content=old_f.read(2048)#一次读取2048个字符
new_f.write(content)#写入
#当读取的内容字符长度小于2048是说明读取完毕
if len(content)<2048:
break#跳出循环
except Exception as e:
print(e)#如果内存满无法读取了,就抛出异常
copyfile2()#到时候文件夹里面会出现一个text_备份2.txt的文件,内容和备份文件一样
备份了text.txt

以上就是关于python文件操作的操作介绍,希望本文对大家学习python文件的操作有帮助,想要了解更多python文件操作的内容,大家可以关注其他相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了利用Python实现读取二进制文件,文章尝试使用Python中的内置open函数使用默认读取模式读取zip文件,下文详细介绍,需要的小伙伴可以参考一下
python框架是对基础代码进行封装和提供相应的应用编程接口,开发人员在使用框架时直接调用封装的应用编程接口可以,提高生产效率和开发速度
这篇文章主要为大家详细介绍了使用pytorch实现线性回归,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
五子棋应该很多朋友都有玩过,这是一款比较简单的棋类游戏。那么我们如果使用python,怎么写一个网络五子棋游戏呢?下面就给大家分享使用Python实现网络五子棋代码,感兴趣的朋友可以参考学习。
c与python对比python不擅长"大量运算"任务,python程序优势在于:编写简单,适合"IO密集型作业"(比如打开文件,下载图片,运行脚本)。python作为知名的"胶水语言",快速实现"计算密集型作业"的方法就是"把c的代码拿过来直接用"。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008