文件操作(十二)——open,read,close,write,seek,truncate
2024-09-24 18:18:42
open函数
#!/usr/bin/env python
#-*- coding:utf8 -*- f = open('xxx','r',encoding='utf-8')
data = f.read()
print(data)
f.close() # readlines() 读多行,以列表的形式返回
f = open('xxx','r',encoding='utf-8')
data = f.readlines() # ['111111\n', '2222\n', '33333\n', '44444\n', '555555']
print(data)
f.close()
des = open('xxx_new', 'w', encoding='utf-8')
des.write(data[0]) # 新文件的内容为 : 111111
des.close()
# writelines 传入一个列表
des = open('xxx_new', 'w', encoding='utf-8')
des.writelines(data)
des.close()
# 追加模式‘a' f = open('xxx','a+',encoding='utf-8')
f.write('666666\n')
data = f.readlines()
print(data)
f.close() # readline() 读一行
f = open('xxx','r',encoding='utf-8')
data = f.readline()
print(data)
f.close() '''
引用另外一个文件的函数
'''
import test_import
test_import.test()
文件模式:
rb模式,wb模式
f = open('xxx','rb') # b 模式不能指定编码
data = f.read()
print(data)
f.close()
'''
hello
2222
33333
你好世界
b'hello\r\n2222\r\n33333\r\n\xe4\xbd\xa0\xe5\xa5\xbd\xe4\xb8\x96\xe7\x95\x8c'
'''
f = open('xxx','rb') # b 模式不能指定编码
data = f.read() # 都出来的内容就是二进制的
print(data.decode('utf-8')) # 把读出来的二进制解码,将显示为正常的字符串
f.close()
'''
hello
2222
33333
你好世界
''' f = open('test_1','wb') # b 模式不能指定编码
str1 = '1111\n'
str2 = '2222\n'
str11 = bytes(str1,encoding='utf-8')
f.write(str11)
f.write(str2.encode('utf-8'))
f.close()
tell(),seeek(),truncate()
# 除了read() 是以字符为单位读取,其他的是以字节为单位读取 f = open('test_1','r',encoding='utf_8',newline='') # newline 还原真的换行符,windows:\r\n,linux:\n
data = f.readline()
print(data.rstrip('\n')) #截掉字符串的空格或指定字符(\t,\n也可以)。
print(f.tell()) # 文件光标的位置
f.seek(0) # 移动光标的位置
print(f.tell()) data = f.readlines()
print(data)
f.close() f = open('test_1','r+',encoding='utf_8')
f.truncate(5) # 截断,必须要有写的权限, 保存截断参数之前的内容
f.close()
seek(), 有三种模式,whence对应取:0,1,2
0:表示从文件开头位置,也是默认模式
1:相对位置,相对位置要以‘b‘形式打开文件
2:倒着seek
def seek(self, offset: int, whence: int = 0) -> int:
f = open('test_1','rb')
print(f.tell()) #
data = f.readlines()
print(f.tell()) #
f.seek(-5,2) # 2 从结尾读取5个字节
print(f.tell()) #
data = f.read()
print(data)
利用seek读取文件最后一行的内容
f = open('test_1','rb')
for i in f:
pos = -2
while True:
f.seek(pos, 2) # 每次从文件末尾偏移pos个字节开始读
data = f.readlines()
if len(data) > 1:
print("文件的最后一行是 %s" %(data[-1]).decode('utf-8'))
break
pos *= 2
最新文章
- MongoDB 聚合管道(Aggregation Pipeline)
- 微信扫码支付~官方DEMO的坑~参数不能自定义
- Java 7 Concurrency Cookbook 翻译 序言
- Oracle10g下载地址--多平台下的32位和64位
- iOS设计模式之中介者模式
- struts2文件下载,动态设置资源地址
- iOS:城市级联列表的使用
- 国内外常用的DNS服务器
- 如何在 Windows Azure 的虚拟机 ubuntu 上面安装和配置 openVPN(二)
- 如何在CHROME里调试前端代码?
- C10K问题2
- OSI参考模型 VS TCP/IP参考模
- tyvj 1150 绳子围点 Pick定理 防溢出策略
- iOS开发系列之远程控制事件
- Linux 用户信息,组信息,密码信息!
- CABasicAnimation 基本动画
- 谈谈Python中的decorator装饰器,如何更优雅的重用代码
- sql 视图学习
- RAND_MAX
- SpringBoot系列: 极简Demo程序和Tomcat war包部署
热门文章
- Mysql抓包工具 - MySQL Sniffer 使用小结 (含带general_log日志)
- Substrings Sort
- Linux实践:模块
- <;<;梦断代码>;>;阅读笔记一
- Java源码--Array
- ThinkCMF项目部署出现无法加载数据库驱动解决方案
- [系统软件]Ubuntu 18.04中的Shutter禁用了“编辑”选项解决
- MYSQL使用中字符编码一坑
- Oracle 数据库启动过程
- Linux下OSG的编译和安装以及遇到的问题