博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python 字典
阅读量:4641 次
发布时间:2019-06-09

本文共 5655 字,大约阅读时间需要 18 分钟。

#####################概念#######################
字典     dict 用{}表示      键值对数据  {key:value}      唯一性     键   都必须是可哈希的    不可变的数据类型就可以当做字典中的键     值    没有任何限制     增:         dic[key] = value         dic.setdefault(key,value)   有则改变,无则添加     可通过可以查询,没有返回None     删:         pop(key)         del dic[key]         dic.clear         popitem #在3.0后默认删除最后一位开始
改         div[key] = value         dic.update(dic2)        把dic2覆盖添加到dic中     查         get(key)         dic[key]         for 循环         setdefault(key)
# dic1=dic1.setdefault('皮长衫',"皮校长")         # print(dic1)
3,字典的其他操作         keys         values         items         解构
#####################作业#####################
1,有如下变量(tu是个元祖),请实现要求的功能
tu = ("alex", [11, 22, {
"k1": 'v1', "k2": ["age", "name"], "k3": (11, 22, 33)}, 44])a.讲述元祖的特性只读列表,只能查,不能增删改b.请问tu变量中的第一个元素"alex"是否可被修改?不可以c.请问tu变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素"Seven"列表可以tu[1][2]['k2'].append('seven')print(tu)d.请问tu变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素"Seven"元祖不可以
2, 字典dic,
dic = {
'k1': "v1", "k2": "v2", "k3": [11, 22, 33]}a.请循环输出所有的keyfor i in dic.keys(): print(i)b.请循环输出所有的valuefor i in dic.values(): print(i)c.请循环输出所有的key和valuefor i in dic.items(): print(i)d.请在字典中添加一个键值对,"k4": "v4",输出添加后的字典dic.setdefault('k4','v4')print(dic)e.请在修改字典中"k1"对应的值为"alex",输出修改后的字典dic['k1'] = 'alex'print(dic)f.请在k3对应的值中追加一个元素44,输出修改后的字典dic['k3'].append(44)print(dic)g.请在k3对应的值的第1个位置插入个元素18,输出修改后的字典dic['k3'].insert(0,18)print(dic)

3,

av_catalog = {

"欧美": {
"www.youporn.com": ["很多免费的,世界最大的", "质量一般"], "www.pornhub.com": ["很多免费的,也很大", "质量比yourporn高点"], "letmedothistoyou.com": ["多是自拍,高质量图片很多", "资源不多,更新慢"], "x-art.com": ["质量很高,真的很高", "全部收费,屌丝请绕过"] }, "日韩": {
"tokyo-hot": ["质量怎样不清楚,个人已经不喜欢日韩范了", "verygood"] }, "大陆": {
"1024": ["全部免费,真好,好人一生平安", "服务器在国外,慢"] } }
av_catalog = {    "欧美": {        "www.youporn.com": ["很多免费的,世界最大的", "质量一般"],        "www.pornhub.com": ["很多免费的,也很大", "质量比yourporn高点"],        "letmedothistoyou.com": ["多是自拍,高质量图片很多", "资源不多,更新慢"],        "x-art.com": ["质量很高,真的很高", "全部收费,屌丝请绕过"]    },    "日韩": {        "tokyo-hot": ["质量怎样不清楚,个人已经不喜欢日韩范了", "verygood"]    },    "大陆": {        "1024": ["全部免费,真好,好人一生平安", "服务器在国外,慢"]    }}# a, 给此["很多免费的,世界最大的", "质量一般"]列表第二个位置插入一个元素:'量很大'。# av_catalog["欧美"]['www.youporn.com'].insert(1,'量很大')# print(av_catalog)# b, 将此["质量很高,真的很高", "全部收费,屌丝请绕过"]列表的"全部收费,屌丝请绕过"删除。# av_catalog["欧美"]['x-art.com'].pop(1)# print(av_catalog)# c, 在此["质量很高,真的很高", "全部收费,屌丝请绕过"]列表中添加"金老板最喜欢这个"。# av_catalog["欧美"]['x-art.com'].append("金老板最喜欢这个")# print(av_catalog)# d, 将此["质量怎样不清楚,个人已经不喜欢日韩范了", "verygood"]列表的"verygood"全部变成大写。# av_catalog["日韩"]['tokyo-hot'][1]=av_catalog["日韩"]['tokyo-hot'][1].upper()# print(av_catalog)# e, 给'大陆'对应的字典添加一个键值对'1048': ['一天就封了']# av_catalog['大陆']['1048']='一天就封了'# print(av_catalog)# f, 删除此"letmedothistoyou.com": ["多是自拍,高质量图片很多", "资源不多,更新慢"]键值对。# av_catalog['欧美'].pop('letmedothistoyou.com')# print(av_catalog)# g, 给此["全部免费,真好,好人一生平安", "服务器在国外,慢"]列表的第一个元素,加上一句话:'可以爬下来'# av_catalog['大陆']['1024'].insert(0,'可以爬下来')# print(av_catalog)
4、有字符串"k:1|k1:2|k2:3|k3:4"处理成字典{'k': 1, 'k1': 2....}(升级题)
 
# a="k:1|k1:2|k2:3|k3:4"# dic={}# b=a.split("|")# print(b)# lis=[]# for i in b:#     lis.append(i.split(':'))# print(lis)# for j in lis:#     dic[j[0]]=int(j[1])# print(dic)#第二种# s= "k:1|k1:2|k2:3|k3:4"# lst=s.split('|')# dic={}# for item in lst:#     k, v =item.split(':')#     dic[k] = int(v)# print(dic)
5、元素分类 有如下值li = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90],将所有大于66的值保存至字典的第一个key中, 将小于66的值保存至第二个key的值中。即: {'k1': 大于66的所有值列表, 'k2': 小于66的所有值列表}
 
# dic={}# a=[]# b=[]# for i in li:#     if i > 66:#          a.append(i)#     else:#         b.append(i)## dic['k1']=a# dic['k2']=b# print(dic)# li = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90]# dic={'key1':[],'key2':[]}# for item in li:#     if item > 66:#         dic['key1'].append(item)#     elif item < 66:#         dic['key2'].append(item)# print(dic)# li = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90]# dic ={}# for item in li:#     if item >66:#         dic.setdefault('key',[]).append(item)#     elif item < 66:#         dic.setdefault('ke2',[]).append(item)# print(dic)#li = [11, 22, 33, 44, 55, 66, 77, 88, 99, 90]# dic={}# for i in li:#     if i > 66:#         if dic.get("key1"):##key1#             dic['key1'].append(i)#         else:#             dic['key1']=[i]#     elif i < 66:#         if dic.get("key2"):#             dic['key2'].append(i)#         else:#             dic['key2']=[i]# print(dic)
6、输出商品列表,用户输入序号,显示用户选中的商品(升级题) 商品列表: goods = [{"name": "电脑", "price": 1999},          {"name": "鼠标", "price": 10},          {"name": "游艇", "price": 20},          {"name": "美女", "price": 998}, ] 要求: 1:页面显示序号 + 商品名称 + 商品价格,如: 1 电脑 1999 2 鼠标 10 … 2:用户输入选择的商品序号,然后打印商品名称及商品价格 3:如果用户输入的商品序号有误,则提示输入有误,并重新输入。 4:用户输入Q或者q,退出程序。
 
goods = [{
"name": "电脑", "price": 1999}, {
"name": "鼠标", "price": 10}, {
"name": "游艇", "price": 20}, {
"name": "美女", "price": 998}]for i in range(len(goods)): good = goods[i] # {"name": "电脑", "price": 1999} print(i+1, good['name'], good['price'])while 1: content = input('请输入你要选择的商品的序号:') if content.upper() == "Q": print("结束购物") break # 判断如果输入的不是数字 或者超过了商品的序号范围 if not content.isdigit() or int(content) > len(goods) or int(content) <= 0: print("对不起, 您输入的内容有误. 请重新输入") continue # 重新执行循环 num = int(content) # 转换成数字 # 还原索引 index = num - 1 good = goods[index] # 根据索引找到你购买的商品 {"name": "美女", "price": 998} print(f"您要购买的商品名称是{good['name']}, 商品的价格是{good['price']}")
 
 
 
 

转载于:https://www.cnblogs.com/zaizai1573/p/10061913.html

你可能感兴趣的文章
ABAP 程序间的调用
查看>>
移动端单屏解决方案
查看>>
web渗透测试基本步骤
查看>>
使用Struts2标签遍历集合
查看>>
angular.isUndefined()
查看>>
第一次软件工程作业(改进版)
查看>>
网络流24题-飞行员配对方案问题
查看>>
Jenkins 2.16.3默认没有Launch agent via Java Web Start,如何配置使用
查看>>
引入css的四种方式
查看>>
iOS开发UI篇—transframe属性(形变)
查看>>
3月7日 ArrayList集合
查看>>
jsp 环境配置记录
查看>>
Python03
查看>>
LOJ 2537 「PKUWC2018」Minimax
查看>>
使用java中replaceAll方法替换字符串中的反斜杠
查看>>
Some configure
查看>>
流量调整和限流技术 【转载】
查看>>
正由另一进程使用,因此该进程无法访问此文件。
查看>>
1 线性空间
查看>>
VS不显示最近打开的项目
查看>>