一、文件处理流程(python默认是utf-8编码)

打开文件函数:open(文件路径,encoding=‘utf-8’)注意:open会检索系统的编码,所以需要调整一致否则报错

例如:fi=open('Alex',encoding=‘utf-8’)

   fi.read() 读取出文件中所有数据

      fi.readline()  一行一行读取,一次读取一行。若是没有了,则读取空行

   readlines()   方法用于读取所有行(直到结束符 EOF)并返回列表,该列表可以由 Python 的 for... in ... 结构进行处理。如果碰到结束符 EOF 则返回空字符串。

fi=li.open('文件名',encoding='utf-8')

print('第1行',f.readline(),end="")
print('第2行',f.readline(),end="")
print('第3行',f.readline(),end="")
print('第4行',f.readline(),end="") =====>> 1111111111111
2222222222222
3333333333333 #每行输出后无空格
4444444444444

注意:一旦使用read后,在使用readline则无效,因为已经读取完了。fi.readlines()  #读取多行,一行输出

写文件操作

f=open('hello.txt','w',encoding="utf-8")
f.write('1111111\n')
f.write('2222222\n')
f.close() #写模式只能写不能读,若文件存在会把内容直接清除掉;不存在则建立一个空文档
#无论是写还是读,都是字符串,不能是数字
f.writeable() #判断是否文件可写
f.writelines([‘555555\n’,'666666\n',‘777777\n’]) #写一个列表传给文件,列表中为内容

追加操作

open('a.txt','a',encoding='utf-8')

# a 在后面追加记录
f=open('a.txt','a',encoding='utf-8')
f.write('')
f.close()
#r+ 即可读又可写
#文件没有修改一说,所谓修改就是覆盖掉
f=open('a.txt','r+',encoding='utf-8')
data=f.read()
print(data)
f.write('123abc')
a=open('a.txt','r+',encoding='utf-8')
data=a.readlines()
a.close() des_f=open('xxx_new','w',encoding='utf-8')
des_f.write(data[0])
des_f.close() #with的好处就是不用关闭文件。
with open('a.txt','w',encoding='utf-8') as f,\
open('xxx_new','r',encoding='utf-8'):
data=a.read()
des_f.write(data)

w+,写读(可读可写)

x+,写读(可读可写)

a+,写读(可读可写)

当文件不能以文本方式进行修改时,我们要用b(字节)模式进行处理。

注意:b 表示以bytes模式(字节)方式读/写,b的方式不能指定编码

rb     r+b  wb  w+b   xb   x+b   ab    a+b

#两种方法进行b模式写操作,一是将文本用bytes()函数转换为字节型,二是直接对其进行‘utf-8’解码,因为系统硬盘上默认是字节形式存储数据的
f=open('xxx_new','wb')
f.write(bytes('11111111\nhello,boy\n123145','utf-8'))
f.write('11111111\nhello,boy\n123145'.encode('utf-8'))
#newline读取文件中的真正换行号  \r\n
f=open('xxx_new','r+',encoding='latin-1',newline='')
print(f.closed) #判断文件是否关闭
print(f.encoding) #文件打开时的编码,与硬盘上编码形式无关
f.closed)       判断文件是否关闭
f.encoding      文件打开时的编码,与硬盘上编码形式无关
f.flush()    把文件从内存buffer(缓冲区)中强制刷新到硬盘中,同时清空缓冲区。
f.name 返回文件名
f.tell() 光标当前所在位置,默认打开时位置为0 以字节方式计算位置,一个汉字3个字节,换行是两个字符\r\n
f.isatty() 是不是终端设备
f.truncate(10) 用于截断文件并返回截断的字节长度。从开头到第十个位
f.seek(offset,whence=0) 移动文件读取指针到指定位置。按字节进行移动,若操作成功,
则返回新的文件位置,如果操作失败,则函数返回 -1.
offset:开始的偏移量,需要移动偏移的字节数

whence:给offset参数一个定义,表示要从哪个位置开始偏移;0代表从文件开头开始算起,1代表从当前位置开始算起,2代表从文件末尾算起。

例如:f.seek(4,5) 表示从第五个位置开始偏移4个字节长度

#seek高级玩法  必须要以'b'模式进行操作,否则会报错
#seek使用时是按字节进行计算的
f=open('seek.txt','rb')
print(f.tell())
f.seek(10,1) #默认第二个参数为0,每次都从第一个位置开始 为1时,相对于光标当前位置
print(f.tell())
f.seek(3,1)
print(f.tell()) ---------->>0 10 13 #参数为2代表相对位置,倒着读,意味着倒着seek,注意第一个参数为负值
f.seek(-10,2)
 
#seek读取文件最后一行,循环文件一行行读取
f=open('日志文件','rb')
for i in f:
print(i)
#日志文件实时读取功能
f=open('a.txt','rb')
for i in f: #若是readlines太占内存,会把所有的都放置内存中,所以推荐使用for i in 文件名:
offs=-10 #定义偏移量,代表日志中一行的字节数
while True:
f.seek(offs,2)
data=f.readlines()
if len(data)>1:
print('文件的最后一行是%s' %(data[-1].decode('utf-8')))
break
offs*=2

Python从入门到超神之文件处理的更多相关文章

  1. python从入门到大神---4、python3文件操作最最最最简单实例

    python从入门到大神---4.python3文件操作最最最最简单实例 一.总结 一句话总结: python文件操作真的很简单,直接在代码中调用文件操作的函数比如open().read(),无需引包 ...

  2. python从入门到大神---Python的jieba模块简介

    python从入门到大神---Python的jieba模块简介 一.总结 一句话总结: jieba包是分词技术,也就是将一句话分成多个词,有多种分词模型可选 1.分词模块包一般有哪些分词模式(比如py ...

  3. python从入门到大神---2、和Python编程相遇的日子

    python从入门到大神---2.和Python编程相遇的日子 一.总结 一句话总结: python2和python3是很不同的,连语法都不同,比如 print 函数打印结果 1.python中pip ...

  4. python从入门到大神---3、浮光掠影python3语法

    python从入门到大神---3.浮光掠影python3语法 一.总结 一句话总结: 语法不必一次记全部,效率太差,用哪部分内容,就把那部分内容全部记下来 1.python3中单引号和双引号的区别是什 ...

  5. python从入门到大神---1、初始化实例、类属性、方法

    python从入门到大神---1.初始化实例.类属性.方法 一.总结 一句话总结: 方法不加括号是代码段:感觉python方法和js,php很类似,不加括号是代码段,加括号变成方法,比如f,f() 1 ...

  6. Python:从入门到实践--第十章--文件和异常--练习

    #.python学习笔记:在文本编辑器中新创建一个文件,写几句话老总结你至此学到的python知识 #其中‘In Python you can’ 打头.将这个文件命名为learning_python. ...

  7. python从入门到实践-10章文件和异常(括号问题)

    #!/user/bin/env python# -*- coding:utf-8 -*- # 1.从文件中读取数据with open('pi_digits.txt') as file_object: ...

  8. Python入门教程 超详细1小时学会Python

    Python入门教程 超详细1小时学会Python 作者: 字体:[增加 减小] 类型:转载 时间:2006-09-08我要评论 本文适合有经验的程序员尽快进入Python世界.特别地,如果你掌握Ja ...

  9. 《手把手教你》系列进阶篇之4-python+ selenium自动化测试 - python几种超神操作你都知道吗?(详细教程)

    1. 简介 今天分享和讲解的超神操作,对于菜鸟来说是超神的操作,对于大佬来说也就是几个简单方法的封装和调用.这里讲解和分享这部分主要是为了培养小伙伴们和童鞋们的面向对象的开发思维,对比这样做的好处让你 ...

随机推荐

  1. jvm 常用参数

    linux 查看 jvm参数配置命令 jinfo -flags pid(当前Java应用的pid)

  2. gitkraken clone报错 Configured SSH key is invalid

    gitkraken clone远程仓库时报错 Configured SSH key is invalid. Please confirm that is properly associated wit ...

  3. 读取文件不是真实的具体路径 setZh.ini

    读取 c:\windows\Syswow64\XX\XX.ini 时内容不正确. 发现真实文件为: C:\Users\用户名\AppData\Local\VirtualStore\Windows\Sy ...

  4. 20175213吕正宏 MyCP(课下任务,必做)

    一.任务详情: 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数: java MyCP -tx XXX1.txt XXX2.bin 用来把文本文件( ...

  5. 字符编码:Unicode和UTF-8之间的关系

    Unicode和UTF-8之间的关系 1. ASCII码 我们知道,在计算机内部,所有的信息最终都表示为一个二进制的字符串.每一个二进制位(bit)有0和1两种状态,因此八个二进制位就可以组合出256 ...

  6. HAProxy 的acl应用

    非常好的博文推荐:http://blog.51cto.com/1992tao/1875563 官方文档:https://cbonte.github.io/haproxy-dconv/1.9/confi ...

  7. nginx屏蔽ip配置

    屏蔽单个IP的命令是 deny 192.168.201.1 封ip段192 deny 192.0.0.0/8 封ip段192.168 deny 192.168.0.0/16 封ip段192.168.2 ...

  8. 利用百度编辑器和IIS限制文件上传的大小

    1.百度编辑器的大小限制 针对不同的文件类型限制大小 例如图片是imageMaxSize ,依次类推 /* 前后端通信相关的配置,注释只允许使用多行方式 */ {     /* 上传图片配置项 */ ...

  9. HBase数据压缩算法编码探索

    摘要: 本文主要介绍了hbase对数据压缩,编码的支持,以及云hbase在社区基础上对数据压缩率和访问速度上了进行的改进. 前言 你可曾遇到这种需求,只有几百qps的冷数据缓存,却因为存储水位要浪费几 ...

  10. 微信小程序获取二维码参数

    var scene = decodeURIComponent(options.scene)