博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
文件操作模式
阅读量:4493 次
发布时间:2019-06-08

本文共 2630 字,大约阅读时间需要 8 分钟。

''' 一: 基本概念 打开文件的模式有三种纯净模式:r(默认的) w a 控制操作文件内容格式的两种模式:t(默认的) b 大前提: tb模式均不能单独使用,必须与纯净模式结合使用 t文本模式:   1. 读写文件都是以字符串为单位的   2. 只能针对文本文件   3. 必须指定encoding参数 b二进制模式:   1.读写文件都是以bytes/二进制为单位的   2. 可以针对所有文件   3. 一定不能指定encoding参数 ''' ''' 二 打开文件模式详解 1. r只读模式: 在文件不存在时则报错,文件存在文件内指针直接跳到文件开头 with open('a.txt',mode='rt',encoding='utf-8') as f:     print(f.readlines()) 用户认证功能 inp_name=input('请输入你的名字: ').strip() inp_pwd=input('请输入你的密码: ').strip() with open(r'db.txt',mode='rt',encoding='utf-8') as f:     for line in f:         # 把用户输入的名字与密码与读出内容做比对         u,p=line.strip('\n').split(':')         if inp_name == u and inp_pwd == p:             print('登录成功')             break     else:         print('账号名或者密码错误') 2. w只写模式: 在文件不存在时会创建空文档,文件存在会清空文件,文件指针跑到文件开头 with open('b.txt',mode='wt',encoding='utf-8') as f:     print(f.writable())     print(f.readable())     f.write('你好\n')     f.write('我好\n') # 强调:在文件不关闭的清空下,后写的内容一定跟着前写内容的后面     f.write('大家好\n')     f.write('111\n222\n333\n')     lines=['1111','22222','33333']     for line in lines:         f.write(line)     f.writelines(lines) #相当于一个for循环     注册功能:     a只追加写模式: 在文件不存在时会创建空文档,     文件存在会将文件指针直接移动到文件末尾     name=input('username>>>: ').strip()     pwd=input('password>>>: ').strip()     with open('db1.txt',mode='at',encoding='utf-8') as f:         info='%s:%s\n' %(name,pwd)         f.write(info)  #a 追加就不会清除再写     with open('c.txt',mode='at',encoding='utf-8') as f:         f.write('44444\n')         f.write('55555\n')         print(f.readable())         print(f.writable())     r+, 读写【可读,可写】     w+,写读【可读,可写】     a+, 写读【可读,可写】     with open('b.txt',mode='r+t',encoding='utf-8') as f:         print(f.readable())         print(f.writable())         print(f.readline())         f.write('你好啊')    '''     # b: 读写都是以二进制位单位 # with open('b.txt',mode='rb') as f: #     data=f.read() #     print(data,type(data)) #     print(data.decode('utf-8')) # with open('1.png',mode='rb') as f: #     data=f.read()#1。png是图片 不再utf-8 无法解码 #     print(data) # # with open('d.txt','wb') as f: #     f.write('你好'.encode('gbk'))     #存为了gbk模式 读的时候pycharm默认读utf-8 所以出现乱码 #复制功能 # with open('1.png',mode='rb') as f: #     data=f.read() # # with open('2.png',mode='wb') as f: #     f.write(data) # src_file=input('源文件路径: ').strip() # #获取源文件的路径保存到src_file中 # dst_file=input('目标文件路径: ').strip() # #获取你想将复制文件放在哪里的路径 同时可以命名你的复制文件名 # with open(r'%s' %src_file,mode='rb') as read_f,open(r'%s' %dst_file,mode='wb') as write_f: #     #可以通过%s %() 的方式读入路径 #     for line in read_f:#把read_f 中的一行一行的读出来放入write_f #         # print(line) #         write_f.write(line)

转载于:https://www.cnblogs.com/OutOfControl/p/9681287.html

你可能感兴趣的文章
package,继承,访问修饰符
查看>>
Freepbx
查看>>
DBS:TestSystem
查看>>
【共读Primer】51.[6.3]返回类型和return语句--列表初始化返回值 Page203
查看>>
第一次作业
查看>>
是否需要有代码规范
查看>>
SQL*Plus 系统变量之14 - DEF[INE]
查看>>
桥叔时间
查看>>
耦合内聚封装
查看>>
qbxt联赛集训d1t3
查看>>
vprintf 和 vsnpintf 的用法
查看>>
201671030108 +词频统计软件项目报告
查看>>
CDOJ 1135 邱老师看电影 概率dp
查看>>
Android编译系统中的Android.bp【转】
查看>>
linux字符设备学习笔记【原创】
查看>>
UnzipUtil
查看>>
2012 Multi-University Training Contest 1
查看>>
实验三
查看>>
如何解决mysql中读取含表情符号的内容无法识别的问题
查看>>
PAT 1002 写出这个数 (20) (Basic Level)
查看>>