前言:
作者:神的孩子在歌唱
这是我听老师讲课做的笔记
大家好,我叫陈运智,大家可以叫我智
open
(‘文件名称’,'打开模式’)r
(只读,指针再头) w
(只写,存在覆盖,不存创新) a
(追加) b
(二进制格式)close()
方法关闭文件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()#输出完成后会自动关闭文件
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文件然后写入
f.write('\r\n')
f.writelines(['人生','就是','不断的学习'])
print('\n')
f.close()
#读取文件
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
本人博客:https://blog.csdn.net/weixin_46654114
转载说明:跟我说明,务必注明来源,附带本人博客连接。
请给我点个赞鼓励我吧