day 8 - 1 文件操作
2018-11-03 08:49:40来源:博客园 阅读 ()
文件操作
注意:
1. r+ 最为常用
2.encoding 的编码格式一定要与文件编码格式一致
读取 r rb
#在本地创建 txt 格式的文件默认使用 gbk 格式 f = open('e:/py/file.txt',mode='r',encoding='gbk') content = f.read() print(content,type(content)) f.close() # b 二进制模式 bytes f= open('e:/py/file.txt',mode='rb') content = f.read() print(content,type(content)) f.close()
只写 w wb
#只写 w #我们写入的格式为 utf-8 那么当我们查看时也要使用 utf-8 格式 #没有该文件 w 会创建文件 f = open('e:/py/test.txt',mode='w',encoding='utf-8') f.write('正在写入...') f.close() #存在该文件 会覆盖写入 #即只写的逻辑为 先清空文件在写入 f = open('e:/py/test.txt',mode='w',encoding='utf-8') f.write('已写入.') f.close() #wb 写入 #默认写入 bytes 类型 需要使用 encode 转换为 str 类型 #写入与文件默认格式不同的类型 如:utf-8 会自动转换 f = open('e:/py/test.txt',mode='wb') f.write('sfssg个人是的.'.encode('gbk')) f.close()
追加 a ab
#追加 a #追加与文件默认格式不同的类型 如:utf-8 不会自动转换 #默认会自动追加在文件光标的位置(即有文字的最后一位上) f = open('e:/py/test.txt',mode='a',encoding='gbk') f.write('追加...') f.close() #ab 追加 #追加与文件默认格式不同的类型 如:utf-8 不会自动转换 f = open('e:/py/test.txt',mode='ab') f.write('方式...'.encode('utf-8')) f.close()
读写 r+ 最常用
#读写时的文件必须和源文件编码一致 #读写的位置是在读完后的最有一个字符后面 #试想在 r+ 模式下 改变读写顺序 #会在文件开头写入 没写入一个字符变会替换一个字符 f = open('e:/py/test.txt',mode='r+',encoding='utf-8') print(f.read()) f.write("...") f.close() #r+ 也存在 bytes 类型 r+b #要与源文件编码一致 f = open('e:/py/test.txt',mode='r+b') print(f.read()) f.write("你就能看".encode('gbk')) f.close()
写读 w+ 不常用
#还是先清除 在添加 所以没什么用 #w+ 也存在 bytes 类型 w+b f = open('e:/py/test.txt',mode='w+',encoding='utf-8') f.write("...") print(f.read()) f.close() #w+ 与 seek 调节光标 #没什么用 f = open('e:/py/test.txt',mode='w+',encoding='utf-8') f.write("...") f.seek(0) #光标在 0 的位置 print(f.read()) #读出结果 f.close()
追加 a+
#与 a 的区别在于 a 只可以执行一个动作 #a+ 可以执行多步 #a+ 也存在 bytes 类型 a+b f = open('e:/py/test.txt',mode='a+',encoding='gbk') f.write('追加...') print(f.read()) #这样仍然读不到内容 因为光标在最后 f.close() # a+ 与 seek f = open('e:/py/test.txt',mode='a+',encoding='gbk') f.write('追加...') f.seek(0) #光标置于 0 的位置 print(f.read()) f.close()
功能详解
read 与 seek
#按照字符读出 read 读出来的都是字符 #字符是能看到的最小单位 #要与源文件编码一致 f = open('e:/py/test.txt',mode='r+',encoding='gbk') print(f.read(3)) f.close() #read 结合 seek #seek 是按照字节来读取的 f = open('e:/py/test.txt',mode='r+',encoding='gbk') f.seek(4) #gbk 每个汉字 2 个字节 utf-8 每个汉字 3 个字节 print(f.read()) f.close()
tell 获取光标位置
f = open('e:/py/test.txt',mode='r+',encoding='gbk') f.seek(4) #按照字节定义光标位置 print(f.tell()) f.close()
移动光标读取后三个字
f = open('d:/py/file.txt',mode='r+',encoding='utf-8') f.readline() #读取一行使光标移动到末尾 f.seek((f.tell())-9) #先锁定光标位置 在进行移动 print(f.read()) f.close()
readable、readline、readlines 与 truncate
f = open('e:/py/test.txt',mode='r+',encoding='gbk') #print(f.readable()) #是否可读 返回值:true false #print(f.readline()) #每次读一行,即一行一行的读 #print(f.readlines()) #把每一行当做一个元素,添加到 list 中 f.truncate(2) #对源文件截取一段数据用来更改,并覆盖源文件 f.close()
读取第二行内容
f = open('e:/py/test.txt',mode='r+',encoding='gbk') f.readline() f.seek(f.tell()) print(f.readline()) f.close()
读整个文件
#for 循环写法 #循环打印出每一行(包括换行符) #读文件时 要分段读 因为你不知道文件有多大 f = open('e:/py/test.txt',mode='r+',encoding='gbk') for i in f: print(i) f.close() #with 写法(自动关闭——close) #可以同时打开多个文件 with open('e:/py/test.txt',mode='r+',encoding='gbk') as file: print(file.read()) with open('e:/py/test.txt',mode='r+',encoding='gbk') as file,\ open('e:/py/file.txt',mode='r+',encoding='gbk') as file2: print(file.read()) print(file2.read())
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- python day1-requests 2019-08-13
- python_0基础开始_day07 2019-08-13
- PythonDay08 2019-08-13
- python day2-爬虫实现github登录 2019-08-13
- python 之 前端开发(form标签、单选框、多选框、file上传文 2019-08-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash