标签:内置函数 系统命令 例子 hand 句柄 开始 流程 元素 nes
我们用python编写的程序放入到硬盘以永久保存,其中涉及到应用程序来操作硬件,而程序却无法直接操作硬件,需要操作系统作为中介,即操作系统将硬件操作封装成简单的接口供用户/应用程序使用。因此,文件操作通过操作系统供给应用程序来操作硬盘虚拟概念,用户或者应用程序可通过操作文件,将数据永久保存。
首先,简单介绍一个例子:
1 f = open(‘F:\pingguo.txt‘,‘r‘,encoding= ‘utf-8‘) # 打开文件,将文件赋值给一个变量f 2 data = f.read() 读取文件里面的内容 3 print(data) 4 f.close() # 关闭文件
通过上面简单例子可以看出,变量f,其实也就是变量f_obj,f_handler,f_h,fh,即文件句柄open()函数是python的内置函数(其内部调用的是windows的系统命令),对文件的操作流程可以简述为:
1,打开文件,产生文件句柄
2,对文件句柄进行操作
3,关闭文件句柄
通过对列表,字典等增删改查一样,文件也有类似操作,但也有很大的不同,接下来分别对文件按读,写,追加等操作。首先是读操作:在python中,读操作为‘r‘,即mode =‘r‘。但对于r模式,mode可以默认不写.
读操作通常由几种读方法,以下一一来介绍。
1 1. 文件内容全部读取 read() 2 f = open(‘F:\诗歌.txt‘, encoding=‘utf_8‘, mode = ‘r‘) 3 content = f.read() 4 print(content) 5 f.close()
显示结果为:
‘‘‘E:\python3.6.5\python.exe G:/PythonFile/week1/骑士计划/week_3/day_1/上课内容.py 杨柳青青江水平, 闻郎江上唱歌声。 东边日出西边雨, 道是无情却有情。 Process finished with exit code 0‘‘‘
1 f = open(‘F:\诗歌.txt‘,encoding= ‘utf-8‘, mode = ‘r‘) 2 content = f.read(10) 3 print(content) 4 f.close()
# 输出结果为: ‘‘‘杨柳青青江水平, 闻
从输出结果可以看出,在读模式下,是按照字符读取数据,其中第一行最后一个空格也占用一个字符。
1 f = open(‘F:\诗歌.txt‘,encoding= ‘utf-8‘, mode=‘r‘) 2 print(f.readline().strip()) 3 print(f.readline().strip()) 4 print(f.readline().strip()) 5 print(f.readline().strip()) 6 print(f.readline().strip()) 7 f.close()
结果:
杨柳青青江水平,
闻郎江上唱歌声。
东边日出西边雨,
道是无情却有情。
每一次只读取一行代码,若没有strip()函数,则每读取一行都会空一行再读取下一行,当readline()多了,不会报错
1 4 按行读取,并返回一个list 2 f = open(‘F:\诗歌.txt‘,encoding=‘utf-8‘,mode=‘r‘) 3 content = f.readlines() # [‘杨柳青青江水平,\n‘, ‘闻郎江上唱歌声。\n‘, ‘东边日出西边雨,\n‘, ‘道是无情却有情。‘] 4 print(content) 5 f.close()
输出结果为一个列表,每一行内容代表一个元素,每一行最后都有一个换行符。
1 f = open(‘F:\诗歌.txt‘,encoding=‘utf-8‘,mode=‘r‘) 2 for line in f: 3 print(line) 4 f.close()
‘‘‘杨柳青青江水平, 闻郎江上唱歌声。 东边日出西边雨, 道是无情却
可以看出,循环输出是每一行每一行执行,有空行,为了将空行删除使用line.strip()函数,如下:
1 f = open(‘F:\诗歌.txt‘,encoding=‘utf-8‘,mode=‘r‘) 2 for line in f: 3 print(line.strip()) 4 f.close()
一般在处理大量数据情况下,建议使用for循环,主要是在大量数据的文件下,用其他方法读是将文件所有数据都放入内存,将导致占用内存空间变大,消耗内存,而for循环则是将数据一行一行读入内存,每读完一行后就销毁,节省了内存的消耗。
1 f = open(‘F:\诗歌.txt‘,mode=‘rb‘) 2 content = f.readlines() 3 print(content) 4 f.close()
bytes方式进行读取,因此,不需要encode = ‘utf-8‘
# 输出结果以bytes方式进行输出:
‘‘‘‘[b‘\xe6\x9d\xa8\xe6\x9f\xb3\xe9\x9d\x92\xe9\x9d\x92\xe6\xb1\x9f\xe6\xb0\xb4\xe5\xb9\xb3\xef‘
b‘\xbc\x8c\r\n‘, b‘\xe9\x97\xbb\xe9\x83\x8e\xe6\xb1\x9f\xe4\xb8\x8a\xe5\x94\xb1\xe6\xad\x8c‘
b‘\xe5\xa3\xb0\xe3\x80\x82\r\n‘, b‘\xe4\xb8\x9c\xe8\xbe\xb9\xe6\x97\xa5\xe5\x87\xba\xe8\
\xbf\xe8\xbe\xb9\xe9\x9b\xa8\xef\xbc\x8c\r\n‘, b‘\xe9\x81\x93\xe6\x98\xaf\xe6\x97\xa0\xe6‘
b‘\x83\x85\xe5\x8d\xb4\xe6\x9c\x89\xe6\x83\x85\xe3\x80\x82‘]...
1 f = open(‘F:\不行.jpg‘,mode=‘rb‘) 2 content = f.read() 3 print(content) # b‘\xff\xd8\xff\xe0\x00\x10JFIF\x00\x01\x01\x00\x00H\x00H\x00\x00\xf....... 4 f.close()
1 f = open(‘F:不行.jpg‘,mode=‘rb‘) 2 content = f.read(9) # b‘\xff\xd8\xff\xe0\x00\x10JFI‘ 模式下,按照字节读取 3 print(content) 4 f.close()
1 f = open(‘F:\诗歌.txt‘,encoding=‘utf-8‘,mode=‘r+‘) 2 content = f.read(3) 3 print(content) 4 f.write(‘666‘) 5 f.close()
操作为先读取文件内3个字符后,光标移动到文件内容最后,再添加内容‘666‘
1 f = open(‘诗歌.txt‘,encoding=‘utf-8‘,mode=‘r+‘) 2 f.write(‘深圳你好!‘) 3 f.close()
‘‘‘深圳你好!水平, 闻郎江上唱歌声。 东边日出西边雨, 道是无情却有情。‘‘‘
从结果可知,不读而直接写会导致光标直接从开始覆盖。
1 # 报错 2 # f = open(‘诗歌.txt‘,mode=‘rb‘) 3 # # content = f.read(10) 4 # # print(content) 5 # f.write(‘666‘) 6 # f.close()
# 若没有文件,则先创建文件后再写内容
# 若有文件,则先清空原文件内容,再写入新内容。
1 f = open(‘诗歌.txt‘,encoding=‘utf-8‘,mode=‘w‘) 2 f.write(‘深圳市南山区世外桃源。。。‘) 3 f.close()
1 f = open(‘F:\不行.jpg‘,mode=‘rb‘) 2 content = f.read() # 将图片信息保存到变量 3 print(content) # b‘\xff\xd8\xff\xe0\x00\x10JFIF........ 4 f1 = open(‘不行1.jpg‘,mode=‘wb‘) 5 f1.write(content) 6 f.close() 7 f1.close()
非文字文件,先以bytes格式进行读出(rb),再用bytes格式进行写入(wb)
1 f = open(‘诗歌.txt‘,encoding=‘utf-8‘,mode=‘w+‘) 2 f.write(‘深圳市南山区世外桃源。。。‘) # 先清空内容 3 f.seek(3) # 移动光标位置,是按字节移动,在utf-8模式下,每个文字移动三个字节,若为非3的倍数,则报错 4 content = f.read() 5 print(content) 6 f.close()
没有文件时,将创建文件并将内容写进去
有文件时,直接在文件的最后面追加内容
1 f = open(‘t1.txt‘,encoding=‘utf-8‘,mode=‘a‘) 2 f.write(‘\n你是我的小丫小苹果。。。。‘) 3 f.close()
其他方法如: ab a+ a+b这里就不介绍了。
标签:内置函数 系统命令 例子 hand 句柄 开始 流程 元素 nes
原文地址:https://www.cnblogs.com/colin1314/p/9472309.html