
今天,已经系统的学习了一下文件相关操作!对三级菜单代码进行的优化:
菜单文件:以字典格式
menu.txt
{'第一层':{'第二层':{'第三层':['内容1','内容2','内容3']}},'第一层2':{'第二层2':{'第三层2':['内容12','内容22','内容32']}}}
增加代码在开头如下:
with open('menu.txt','r',encoding='utf-8') as f:
info=eval(f.readline())#打开并转成字符
如以便得以实现菜单存在文件中!
同时学习了集合的使用:
1 list_1=[1,2,3,4,6,3,2]
2 print('原始列表1:',list_1)
3 list_2=[3,46,6,2]
4 print('原始列表2:',list_2)
5
6 list_1=set(list_1)#去重为集合
7 print('去重列表1:',list_1)
8
9 print('合并列表1、2后:',list_1.union(list_2))#两个列表合并去重
10 print('列表1与列表2的交集:',list_1.intersection(list_2))#两个列表有交集的元素
11 print('列表1差集列表2:',list_1.difference(list_2))#列表1减去在列表2中有出现的元素
12 print('列表1是否是列表2的子集:',list_1.issubset(list_2))#返回真、假
13 print('列表1是否是列表2的父集:',list_1.issuperset(list_2))#返回真、假
14 print('列表1与列表2无交集:',list_1.isdisjoint(list_2))#无交集返回真、有交集返回假
15 print('列表1与列表2的对称差集:',list_1.symmetric_difference(list_2))#列表1对列表2的差集加上列表2对列表1的差集的集合,即去除两个列表中交集元素
内容为
字典的用法英文
#<字典>
#help(dict)
#
#
#字典一种key - value 的数据类型,使用就像我们上学用的字典,通过笔划、字母来查对应页的详细内容。
#
#字典的特性:dict是无序的,key必须是唯一的,所以天生去重。字典里没有下标
#
#key-value
#号码(下标):内容(可以重复)
# print (' ')
print ('-------------创建字典的方法壹-------------------')
dict1 = {'num2': 'LongZe', 'num3': 'XiaoZe','num4':'Maliy','num5':'Jack','num6':'Hagan','num7':'Cahill'}
print(dict1) print (' ')
print ('-------------创建字典的方法二-------------------')
dict2 = dict(鱼='让编程改变',书='读嘟嘟',笔='写写写')
print(dict2) print (' ')
print ('-------------创建字典的方法三-------------------')
dict3 =dict((('f',70),('i',50),('s',111),('h',104)))
print(dict3) print(' ')
print('------------------------字典增加-----------------')
dict1['yyy'] = '追加字典'
print(dict1) print(' ')
print('------------------------字典修改-----------------')
dict2['鱼'] = '修改字典'
print(dict2) print(' ')
print('------------------------字典删除方法壹-----------')
dict1.pop('num3')
print(dict1) print(' ')
print('-----------py通用方法---字典删除方法二-----------')
del dict1['num4']
print(dict1) print(' ')
print('------------字典删除方法三随机删除一个---------')
dict1.popitem()
print(dict1) print(' ')
print('------------------字典查找方法壹返回True---------')
'num2' in dict1
print('num2' in dict1) print(' ')
print('---------------字典查找方法二----安全获取的方法--')
cz = dict1.get("num2")
print(cz) print(' ')
print('------------------字典查找方法三-----------------')
dict1["num2"]
print(dict1["num2"]) print ('如果一个key不存在,就报错,get不会,不存在只返回None') print(' ')
print(' ')
字典的用法
#多级字典嵌套及操作
av_catalog = {
"欧美":{
"www.youporn.com": ["很多免费的,世界最大的","质量一般"],
"www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
"letmedothis.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
"x-aryrtyrtt.com": ["质量很高,真的很高","全部收费,屌比请绕过"]
},
"日韩":{
"tokyo-hottuiyui": ["质量怎样不清楚","听说是收费的"]
},
"大陆":{
"1024hkhkhkhkhkh": ["全部免费,真好,好人一生平安","服务器在国外,慢"]
}
} av_catalog["大陆"][""][1] += ",可以用爬虫爬下来" print(av_catalog["大陆"][""])
#ouput
['全部免费,真好,好人一生平安', '服务器在国外,慢,可以用爬虫爬下来']
多级字典嵌套及操作
#以下代码复制到python(3.6.2rc2)下 按F5 可以正常执行,对比学习。QQ:124111294欢迎
#字典的其它姿势 #values 打印不包括keys所有的值
info.values()
dict_values(['LongZe Luola', 'XiaoZe Maliya']) #keys 打印所有keys的值
info.keys()
dict_keys(['stu1102', 'stu1103']) #setdefault 创建一个新的值,寻找某值,寻找不到创建
info.setdefault("stu1106","Alex")
'Alex'
info
{'stu1102': 'LongZe Luola', 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}
info.setdefault("stu1102","龙泽萝拉")
'LongZe Luola'
info
{'stu1102': 'LongZe Luola', 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'} #update 合并两字典,交叉就覆盖,没有就添加。
info
{'stu1102': 'LongZe Luola', 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'}
b = {1:2,3:4, "stu1102":"龙泽萝拉"}
info.update(b)
info
{'stu1102': '龙泽萝拉', 1: 2, 3: 4, 'stu1103': 'XiaoZe Maliya', 'stu1106': 'Alex'} #items 字典转成列表
info.items()
dict_items([('stu1102', '龙泽萝拉'), (1, 2), (3, 4), ('stu1103', 'XiaoZe Maliya'), ('stu1106', 'Alex')]) #通过一个列表生成默认dict,有个没办法解释的坑,少用吧这个
#初始一个新的字典,每个KEY用同一个值<值等于浅COPY,类似快捷方式>
dict.fromkeys([1,2,3],'testd')
{1: 'testd', 2: 'testd', 3: 'testd'}
字典的其它姿势
#以下代码复制到python(3.6.2rc2)下 按F5 可以正常执行,对比学习。QQ:124111294欢迎
#循环dict<字典> #方法1 #通过key寻找打印
for key in info:
print(key,info[key]) #方法2 #把字典转成列表,然后打印列表里的('k','v')
for k,v in info.items(): #会先把dict转成list,数据大时莫用
print(k,v)
循环dict<字典>