Python 三级菜单-字符编码和转码-集合的操作-文件的操作
三级菜单:
menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{}, '网易':{}, 'google':{} }, '中关村':{ '爱奇艺':{}, '汽车之家':{}, 'youku':{}, }, '上地':{ '百度':{}, }, }, '昌平':{ '沙河':{ '老男孩':{}, '北航':{}, }, '天通苑':{}, '回龙观':{}, }, '朝阳':{}, '东城':{}, }, '上海':{ '闵行':{ "人民广场":{ '炸鸡店':{} } }, '闸北':{ '火车战':{ '携程':{} } }, '浦东':{}, }, '山东':{}, }
exit_flag = False current_layer = menu #标志位,用于循环 layers = [menu] #用于存储循环后的list,记录最后一项的添加项。 while not exit_flag: for k in current_layer: #循环打印字典 print(k) choice = input('>>>').strip() if choice == 'b': #退出 current_layer = layers[-1] #输出列表的最后一项 layers.pop() #删除列表的最后一项。用于返回上一级 elif choice in current_layer: #正确选择选项 layers.append(current_layer) #添加字典到列表最后一项 current_layer = current_layer[choice] #进入下一层 else: #输入错误 continue
(思路:使用标志位进行大循环。运用for进行循环打印,使用列表添加删除实现进入下一级和返回上一级)
字符编码和转码
1.在python2默认编码是ASCII, python3里默认是unicode
2.unicode 分为 utf-32(占4个字节),utf-16(占两个字节),utf-8(占1-4个字节), so utf-16就是现在最常用的unicode版本, 不过在文件里存的还是utf-8,因为utf8省空间
3.在py3中encode,在转码的同时还会把string 变成bytes类型,decode在解码的同时还会把bytes变回string
集合操作
集合是一个无序的,不重合的数据组合。
作用:
- 去重,把一个列表变为一个集合,就自动去重了。
- 关系测试,测试几组数据之前的交集、差集、并集等关系。
# s = set([1,23,45,6,"hello",(1,23,4)]) #创建一个数值集合,集合内的元素必须是不可哈希 # # (不可改变的){1, 'hello', 6, 45, 23, (1, 23, 4)} # t = set('Hello') #创建一个唯一字符集合 {'e', 'l', 'H', 'o'} # print(s,t) # s = set([1,2,3,4]) # t = set([3,4,5,6]) # a = s | t #s和t的并集 s.union(t) {1, 2, 3, 4, 5, 6} # b = s & t #s和t的交集 s.intersection(t) {3, 4} # c = s ^ t #求对称差集(在s和t中共同存在以外的)s.symmetric_difference(t) {1, 2, 5, 6} # d = s - t #期差集 (s中存在,t中不存在的)s.difference(t) {1, 2} # print(a,b,c,d) # 基本操作 s = set([1,2,3,4]) t = set([1,2,3,4,5,6]) # s.add("x") #添加一项 # s.update([3,4,5,6,"YY"]) #添加多项 # s.remove(1) #移除集合中的某一项 # a=len(s) #len集合长度 # a = s in t #s是否是t的成员 # b = s not in t #s是否不是t的成员 # 测试是否 s 中的每一个元素都在 t 中 # b = t.issubset(s) # b = s <= t # 测试是否 t 中的每一个元素都在 s 中 # b = s.issuperset(t) # b = s >= t # s.copy() #集合的浅Copy{1, 2, 3, 4}
总结:1.集合的创建,列表中的元素必须是可哈希的 2.添加元素add、update,删除romover,长度len,del X,复制s.copy。3.关系符:|、&、^、-、<=、>=
文件操作
对文件的操作流程
1.打开文件,得到一个文件句柄并复制给一个变量
2.通过句柄对文件进行操作
3.关闭文件
# f = open('file') #打开文件 文件句柄 ,文件句柄 = open('文件路径', '模式') # first_line = f.readline() #读取文件第一行 # print('first_line:',first_line) # # print("我的分隔符".center(30,'-')) # data = f.read() #读取剩下的,***文件大时误用*** # print(data) # f.close()
打开文件模式:
- r,只读模式(默认)。
- w,只写模式。【不可读;不存在则创建;存在则删除内容;】
- a,追加模式。【可读; 不存在则创建;存在则只追加内容;】
"+" 表示可以同时读写某个文件
- r+,可读写文件。【可读;可写;可追加】
- w+,写读
- a+,同a
"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)
- rU
- r+U
"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)
- rb
- wb
- ab
# f = open('file','r',encoding='utf-8') #只读模式,默认模式 # print(f.read()) # f.close() # f = open('file','w',encoding='utf-8')#w,只写模式【不可读;不存在则创建;存在则清空内容后添加】 # print(f.writelines('add')) #add # f.close() # f = open('file','a',encoding='utf-8') #a,追加模式【可读;不存在则创建;存在则只追加内容;】 # print(f.write('add')) # f.close() # f = open('file','r+',encoding='utf-8') # #print(f.write('pengdsdap')) # print(f.read()) # f.close()
高效读取方法:
# #高效读取方法: # f = open('file','r',encoding='utf-8') # for line in f: # print(line.strip())
with语句
为了避免打开文件后忘记关闭,可以通过管理上下问:
# with open('file','r',encoding='utf-8') as f: # print(f.read())
当with代码模块执行完毕,内部会自动关闭并释放文件资源。
Python2.7版本以后,with同时只多个文件的管理上下文:
# with open('file','r',encoding='utf-8') as f,open('file2','r',encoding='utf-8') as f2: # print(f2.read()) # print(f.read())
seek和tell用法
>>> f=open("aaa.txt","w") #以只写的形式打开一个叫做aaa.txt的文件 >>> f.write("my name is liuxiang,i am come frome china") #写入内容 41 >>> f.close() #关闭文件 >>> f=open("aaa.txt","r") #以只读打开文件 >>> f.read() #读取内容 'my name is liuxiang,i am come frome china' >>> f.seek(3,0) #“0”代表从文件开头开始偏移,偏移3个单位 >>> f.read(5) #从偏移之后的指针所指的位置(即“n”)开始读取5个字符 'name ' >>> f.tell() #显示现在指针指在哪个位置(即“i”的位置) 8 >>> f.readline() #读取这一行剩下的内容 'is liuxiang,i am come frome china' >>> f.seek(0,2) #“2”代表从末尾算起,“0”代表偏移0个单位 41 >>> f.read() '' #因为是从末尾算起,内容已结束。所以读取内容为空
总结:1.文件的操作流程 2.打开文件的模式r、a、w和r+、w+、a+。3.读取方式:read、readline、高效读取方式。4.with语句打开文件忘记关闭5.seek、tell?