python文件操作

1.文件操作基本流程

计算机系统分为:计算机硬件,操作系统,应用程序三部分。

我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件,众所周知,应用程序是无法直接操作硬件的,这就用到了操作系统。操作系统把复杂的硬件操作封装成简单的接口给用户/应用程序使用,其中文件就是操作系统提供给应用程序来操作硬盘虚拟概念,用户或应用程序通过操作文件,可以将自己的数据永久保存下来。

有了文件的概念,我们无需再去考虑操作硬盘的细节,只需要关注操作文件的流程:

   1. 打开文件,得到文件句柄并赋值给一个变量
  f=open('a.txt','r',encoding='utf-8') #默认打开模式就为r

 2. 通过句柄对文件进行操作
 data=f.read()

 3. 关闭文件
  f.close()
关闭文件的注意事项:
打开一个文件包含两部分资源:操作系统级打开的文件+应用程序的变量。在操作完毕一个文件时,必须把与该文件的这两部分资源一个不落地回收,回收方法为:
1、f.close() #回收操作系统级打开的文件
2、del f #回收应用程序级的变量

其中del f一定要发生在f.close()之后,否则就会导致操作系统打开的文件还没有关闭,白白占用资源,
而python自动的垃圾回收机制决定了我们无需考虑del f,这就要求我们,在操作完毕文件后,一定要记住f.close()

虽然我这么说,但是很多同学还是会很不要脸地忘记f.close(),对于这些不长脑子的同学,我们推荐傻瓜式操作方式:使用with关键字来帮我们管理上下文
with open('a.txt','w') as f:
    pass
 
with open('a.txt','r') as read_f,open('b.txt','w') as write_f:
    data=read_f.read()
    write_f.write(data)

 2. 文件操作

  以什么编码方式储存的文件,就以什么编码打开进行操作

2.1 只读       
      r

rb 需要打开非文字类的文件,不需要添加encoding参数
f = open('lll', mode='r', encoding='utf-8')     # 打开的文件是什么编码方式,就写对应的encoding值
content = f.read()    # open函数帮助转化为unicode,方便用户读
print(content)
f.close()
2.2 只写       
       w 没有文件就会创造,有的话先清除内容再写

wb 以bytes类型写,不添加encoding参数,在写入内容的后面加.encode('utf-8')
# w
f = open('log', mode='w', encoding='utf-8')
f.write('高清电影')
f.close()

# wb
f = open('log', mode='wb') f.write('高清附近看看纷纷'.encode('utf-8')) f.close()
2.3 追加     
      a

ab 以bytes类型追加,写入内容的后面加.encode('utf-8')
f = open('log',mode = 'a', encoding='utf-8')
f.write('好的男孩你加油')
f.close()                               # 追加   光标自动移动到最后一位
2.4 读写(先读后写)    
           r+ 读完之后光标停留在最后,在进行追加写

r+b 以bytes类型读写,写入内容的后面加.encode('utf-8')
f = open('log', mode= 'r+',encoding= 'utf-8')
print(f.read())
f.write('大梦,小梦')
f.close()                  # 光标停留在读结束后,所以属于追加
2.5 写读      
       w+ 先清除再写,读的时候只显示未被覆盖的内容,所以如果不调整光标位置就什么也读不到
f = open('log', mode= 'r+',encoding= 'utf-8')
f.write('aaa')     # 会覆盖
print(f.read())    # 只显示未被覆盖的内容,所以什么也读不到
f.close()

  改进:

f = open('log',mode= 'r+',encoding='utf-8')
f.write('佳琪')
f.seek(0)           # 将光标移动到开头,才能全部都出
print(f.read())     # 读的操作是从光标位置,到文件末尾
f.close()

2.6  光标问题

  seek() 按照字节定光标的位置

f = open('log', mode='r+', encoding='utf-8')
f.seek(3)    # 所以光标是按照字节定位置的,在utf-8编码中,3个字节一个文字              # log文件中的内容  爱国爱党爱业
content = f.read()
print(content)         # 结果: 国爱党爱业
f.close()

  tell() 显示光标当前位置

f = open('log',mode= 'a+',encoding='utf-8')
f.write('佳琪')                   #   此时文档的内容为  爱国爱党爱业佳琪
count = f.tell() # 光标落到最后
f.seek(count - 9)
print(f.read()) # 结果 : 业佳琪
f.close()

 2.7  对句柄循环打印,读全文化

f = open('log',mode= 'r+',encoding='utf-8')
for line in f:
    print(line)

 3.当日练习

1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数。

apple 10 3

tesla 100000 1

mac 3000 2

lenovo 30000 3

chicken 10 3

通过代码,将其构建成这种数据类型:[{'name':'apple','price':10,'amount':3},{'name':'tesla','price':1000000,'amount':1}......] 并计算出总价钱。

2,有如下文件:

-------

alex是老男孩python发起人,创建人。

alex其实是人妖。

谁说alex是sb?

你们真逗,alex再牛逼,也掩饰不住资深屌丝的气质。

----------

将文件中所有的alex都替换成大写的SB。

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

转载于:https://www.cnblogs.com/arrow87/p/9302176.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值