python3文件读写操作(本篇代码大约100行)
- f = open(xxx.txt, "r", encoding="utf-8") 不写“r”(只读)默认是只读方式打开,可以改成“w”(只写,覆盖写,若没有则创建),"a"(只追加写),操作系统有自己的编码,open在打开文件的时候默认使用操作系统的编码(win7\8--->gbk,mac/linux---->utf-8),所以为了避乱乱码可以使用encoding="utf-8"
- f.read(5) 从开头开始读5个字符,中文和英文数字都算是一个字符
- f.write() 多次使用的话就一直在后面写入内容,紧挨着
- f.readline() 按行读,读出来之后除了内容还会打印换行符,所以中间还会空一行
- f.readlines() 将文件所有行读出来存在列表中,按行存储
- for i in f: 这种是常用的循环读取文件内容的办法,因为for循环会把f做成迭代器,这样在读大文件的时候不会像readlines那样直接全部读取到内存中,而是一行一行取,想下面就是读取的时候在第N行需要修改
f = open("test1.txt", "r", encoding="utf-8") #以utf-8编码格式打开文件 n = 0 #设定行数 for i in f: n+=1 if n == 5: #当读到第五行时,就在第五行后面加上test字符串 i = ''.join((i,"test")) print(i.strip()) f.close()
- f.tell() 返回文件读取目前光标所在的位置(python3中如果是utf-8的中文,一个中文代表三个位置,加入读“刘”,f.read(1)就能读出来了,但是f.tell()会显示3)
- f.seek(n,2) 从位置2开始偏移n
- f.flush() 方法是用来刷新缓冲区的,即将缓冲区中的数据立刻写入文件,同时清空缓冲区,不需要是被动的等待输出缓冲区写入。
import time,sys for i in range(30): #print是默认调用了sys.stdout.write()方法将输出打印到控制台 sys.stdout.write("*") #sys.stdout的形式就是print的一种默认输出格式,等于print "%VALUE%" sys.stdout.flush() #强制刷新缓冲区,立刻进行打印,如果没有这一句就会一直在缓存里面,等到30*0.1秒后一次打印,进度条可以用这样的方式打印 time.sleep(0.1) #这两个程序效果是一样的 for i in range(30): print("*",end="",flush=True) time.sleep(0.1)
- f.truncate(size) truncate()方法用于截断文件,如果指定了可选参数 size,则表示截断文件为 size 个字符。 如果没有指定 size,则从当前位置起截断;截断之后 size 后面的所有字符被删除。f.truncate(5)表示只保留5个字符,后面的全部删除
- 文件读写模式总结:从别人博客截来的,感觉总结的不错,注意下,r+(如果直接写文件,则从顶部开始写,覆盖之前此位置的内容,如果先读后写,则会在文件最后追加内容。),而w+是清空覆盖重新写
其他方法:
- fileno() 方法返回一个整型的文件描述符
- isatty() 方法检测文件是否连接到一个终端设备,如果是返回 True,否则返回 False。
文件需要修改的话需要重写新的文件,在写到新的文件的时候可以修改内容(没啥别的办法)。类似下面代码就是这个过程:
f_read = open("test.txt", "r", encoding="utf-8") #以utf-8格式读取出来,不然中文会乱码 f_write = open("test1.txt", "w", encoding="utf-8") #以utf-8格式打开写入,不然写入中文会乱码 number = 0 for i in f_read: number += 1 #第五行加上喔喔喔喔四个字 if number == 5: i = ''.join((i.strip(), "喔喔喔喔\n")) f_write.write(i) f_write.close() f_read.close()
with open(xxx) as f这种表达会自动帮你close文件,推荐使用这种方式。刚刚上面的方式可以改写为如下,功能是一样的:
with open("test.txt", "r", encoding="utf-8") as f_read, open("test1.txt", "w", encoding="utf-8") as f_write: #同时管理多个文件对象 number = 0 for i in f_read: number += 1 #第五行加上喔喔喔喔四个字 if number == 5: i = ''.join((i.strip(), "喔喔喔喔\n")) f_write.write(i)
第一篇我们实现过三级菜单的操作,现在这里我们将三级菜单存人文本中,然后可以对菜单进行增删改操作:
下面是menu1菜单:
{ "广东省":{ "深圳市":{ "罗湖区":{}, "福田区":{}, "南山区":{} }, "广州市":{ "白云区":{}, "天河区":{}, "越秀区":{}, "番禺区":{} }, "东莞市":{ "虎门镇":{}, "樟木头":{}, "常平镇":{}, "大岭山":{} } }, "湖南省":{ "长沙市":{ "雨花区":{}, "岳麓区":{}, "芙蓉区":{} }, "株洲市":{ "天元区":{}, "沪松区":{} }, "邵阳市":{ "新邵县":{}, "大祥区":{}, "武冈":{}, "隆回县":{} } } }
下面是实现代码:
# -*- coding:utf-8 -*- ''' 需求: 1、展示省市县(数据存在文件中) 2、对菜单实现可以增删改省市县 思路: 1、菜单存在文件里面,读取出来是str格式,通过eval(将字符串string对象转化为有效的表达式参与求值运算返回计算结果)转化成字典 2、对比原来的功能多了增加(add)、修改(change)、删除(delete)操作,这里就是多几个if判断 3、用户操作完之后呢,就需要修改完再以str格式写回文件内 ''' #第三版(实用版,通过文件存储信息然后操作) #通过读取文件读取菜单栏 with open("menu1", "r", encoding="utf-8") as f: # str转化成字典 menu_dict = eval(f.read().strip()) #退出的标识位 flag = True #通过变量存储变化的菜单栏 current_menu = menu_dict #刚开始就是一级菜单栏 print(current_menu) #通过列表记录以往的父级菜单 menu_list = [] while flag: print(menu_list) #打印菜单栏内容,跟current_menu有关 for menu in current_menu: print(menu) choice_menu = input("请选择需要查询的地区或增加(add)、修改(change)、删除(delete)操作,b返回上一层,q退出:").strip() #查询 if choice_menu in current_menu: #将父级菜单加入列表 menu_list.append(current_menu) #变量存储子级菜单 current_menu = current_menu[choice_menu] if not current_menu: print("最后一层了") #新增 elif choice_menu == "add": menu_add = input("请输入要增加的内容:").strip() if menu_add in current_menu: print("你输入的已存在!") else: current_menu[menu_add] = {} #修改 elif choice_menu == "change": menu_old = input("请输入你要修改的内容:").strip() if menu_old in current_menu: menu_new = input("请输入你要修改为:") current_menu[menu_new] = current_menu[menu_old] current_menu.pop(menu_old) else: print("你输入要修改的内容不存在!") #删除 elif choice_menu == "delete": menu_delete = input("请输入要删除的内容:").strip() if menu_delete in current_menu: current_menu.pop(menu_delete) else: print("你要删除的内容不存在!") #返回 elif choice_menu == 'b': #如果列表记录无内容证明在第一层,所以就不需要执行返回上一层 if len(menu_list) == 0:continue current_menu = menu_list.pop() #退出 elif choice_menu == 'q': flag = False #如果在第三层直接退出,那么current_menu记录的肯定是第三层内容,所以我们需要拿到第一层所有菜单 if len(menu_list) == 0: continue else: current_menu = menu_list[0] else: print("输入有误!") with open("menu1", "w", encoding="utf-8") as f: #字典转成str写入 new_menu = str(current_menu) f.write(new_menu)