python文件操作

it2022-05-20  54

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


最新回复(0)