zoukankan      html  css  js  c++  java
  • Python--day05_2018.7.6(dic,字典介绍,增删改查,嵌套)

    一.基本数据类型-----字典

    1.介绍

      用{  }大括号括起来使用  key--value 来保存数据

    dic = {"jay","周杰伦","JJ","林俊杰"}

    !**! 注意: 字典的key值必须是可以哈希的,不可以改变的

    已知的可哈希(不可变)的数据类型: int, str, tuple, bool

    不可哈希(可变)的数据类型: list, dict, set

    2.字典的增删改查

      2.1 -----增

      ①dic["国际章"] = "汪峰的老婆"   #在字典中添加["国际章":"汪峰的老婆"]

          dic["国际章"] = "雄壮的老外"   #在字典中把["国际章":"汪峰的老婆"]替换为["国际章":"雄壮的老外"]

      ②dic.setdefault("马蓉","王宝强前任")    #在字典中添加["马蓉","王宝强前任"]

               dic.setdefault("马蓉","宋哲的老婆")    #在字典中已近存在key = 马蓉,所以不做替换

      2.2-----删

        ①ret = dic.pop("晓雪")     #执行pop操作会有返回值,返回key为晓雪对应的value值是什么, 删除key= 晓雪的一对值

        ②del dic("晓雪")              #删除key= 晓雪的一对数值.

        ③dic.popitem()               #在字典中随机删除一对k-v 值

        ④dic.clear()                   #将此字典清空.字典为空{}

      2.3-----改

      dic1 = {"1":"1","2":"2","3":"3"}

      dic2 = {"1":"5","4":"4"}

      dic1.update(dic2)      #将dic2里面的内容更新到dic1,如果key已近存在,进行修改,如果不存在,则直接添加到dic1中.

      2.4-----查

        ①print(dic["艺大师"])    #如果key中有艺大师,则输出艺大师对应的vlaue值,    没有的话程序会报错

        ②print(dic.get("易大师"))       存在则输出对应的vlaue值

                                                             不存在默认会输出  NONE       print(dic.get("易大师","不存在这个值"))    不存在时,修改程序输出的内容

    3.其他操作

        dic = {"id": 123, "name": 'sylar', "age": 18, "ok": "科⽐比"}

    print(dic.keys())  #  输出所有的key值    输出结果类似与列表  dict_keys(['id', 'name', 'age', 'ok'])    

    print(dic.values())   #输出所有的value值   输出结果类似与列表dict_values([123, 'sylar', 18, '科⽐比'])

    解构

    # 解构 a, b = 1, 2

    print(a, b)

    (c, d) = 3, 4

    print(c, d)

    e, f = [1, 2, 3]    # 解构的时候注意数量量必须匹配 print(e, f)  数量不匹配会报错

    4.字典的嵌套

    # 字典的嵌套 dic1 = {  

      "name": "汪峰",   

    "age": 18,   

    "wife": {       

       "name": '章⼦子怡',       

      "age": 28    },   

    "children": [ '第⼀一个⽑毛孩⼦子', '第⼆二个⽑毛孩⼦子'],   

    "desc": '峰哥不不会告我吧. 没关系. 我想上头条的'

    }

    print(dic1.get("wife").get("name"))

    print(dic1.get("children"))

    print(dic1.get("children")[1])

    # day5作业及默写
    #
    # 1,有如下变量(tu是个元祖),请实现要求的功能
    #
    # tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11, 22, 33)}, 44])
    # print(tu)
    # a.讲述元祖的特性
    #元祖是不可以被修改的,里面可以存储任何类型的元素数据.
    # b.请问tu变量中的第一个元素"alex"是否可被修改?
    # 不可以被修改
    # c.请问tu变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素"Seven"
    # tu[1][2].get("k2").append("Seven")
    # d.请问tu变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素"Seven"
    # print(type(tu[1][2].get("k3"))) #<class 'tuple'>

    # 2, 字典dic,
    # dic = {'k1': "v1", "k2": "v2", "k3": [11, 22, 33]}
    # a.请循环输出所有的key
    # for i in dic.keys():
    # print(i)
    # b.请循环输出所有的value
    # for i in dic.values():
    # print(i)
    # c.请循环输出所有的key和value
    # for key,value in dic.items():
    # print(key)
    # print(value)
    # d.请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
    # dic["k4"] = "v4"
    # e.请在修改字典中"k1"对应的值为"alex",输出修改后的字典
    # dic["k1"] = "alex"
    # f.请在k3对应的值中追加一个元素44,输出修改后的字典
    # dic.get("k3").append(44)
    # g.请在k3对应的值的第1个位置插入个元素18,输出修改后的字典
    # dic.get("k3").insert(1,"18")
    # print(dic)

    # 3,

    # av_catalog = {
    # "欧美":{
    # "www.youporn.com": ["很多免费的,世界最大的","质量一般"],
    # "www.pornhub.com": ["很多免费的,也很大","质量比yourporn高点"],
    # "letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"],
    # "x-art.com":["质量很高,真的很高","全部收费,屌丝请绕过"]
    # },
    # "日韩":{
    # "tokyo-hot":["质量怎样不清楚,个人已经不喜欢日韩范了","verygood"]
    # },
    # "大陆":{
    # "1024":["全部免费,真好,好人一生平安","服务器在国外,慢"]
    # }
    # }
    # print(av_catalog)
    # a,给此 ["很多免费的,世界最大的","质量一般"]列表第二个位置插入一个 元素:'量很大'。
    # av_catalog.get("欧美").get("www.youporn.com").insert(2,"量很大")
    # b,将此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表的 "全部收费,屌丝请绕过" 删除。
    # av_catalog.get("欧美").get("x-art.com").pop()
    # c,在此 ["质量很高,真的很高","全部收费,屌丝请绕过"]列表中添加"金老板最喜欢这个"。
    # av_catalog.get("欧美").get("x-art.com").append("金老板最喜欢这个")
    # d,将此["质量怎样不清楚,个人已经不喜欢日韩范了","verygood"]列表的 "verygood"全部变成大写。
    # av_catalog.get("日韩").get("tokyo-hot")[1] = av_catalog.get("日韩").get("tokyo-hot")[1].upper()
    # e,给'大陆' 对应的字典添加一个键值对 '1048' :['一天就封了']
    # f,删除此"letmedothistoyou.com": ["多是自拍,高质量图片很多","资源不多,更新慢"]键值对。
    # av_catalog.get("欧美").pop("letmedothistoyou.com")
    # g,给此["全部免费,真好,好人一生平安","服务器在国外,慢"]列表的第一个元素,加上一句话:'可以爬下来'
    # av_catalog.get("大陆").get("1024")[0] = av_catalog.get("大陆").get("1024")[0] +"可以爬下来"
    # print(av_catalog)


    # 4、有字符串 "k:1|k1:2|k2:3|k3:4" 处理成字典 {'k':1,'k1':2....} (升级题)

    # str = "k:1|k1:2|k2:3|k3:4"
    # lst = str.split("|")
    # dic = {}
    # for i in lst:
    # k,v = i.split(":")
    # dic[k] = v
    # print(dic)


    # 5、元素分类
    # 有如下值li= [11,22,33,44,55,66,77,88,99,90],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。
    # 即: {'k1': 大于66的所有值列表, 'k2': 小于66的所有值列表}
    # li= [11,22,33,44,55,66,77,88,99,90]
    # lst1 = []
    # lst2 = []
    # dic = {}
    # for i in li:
    # if i > 66:
    # lst1.append(i)
    # elif i < 66:
    # lst2.append(i)
    # else:
    # continue
    # dic['k1'] = lst1
    # dic["k2"] = lst2
    # print(dic)


    # 6、输出商品列表,用户输入序号,显示用户选中的商品(升级题)

    # 商品列表:


    # 要求:
    # 1:页面显示序号 + 商品名称 + 商品价格,如:
    # 1 电脑 1999
    # 2 鼠标 10
    # …
    # 2:用户输入选择的商品序号,然后打印商品名称及商品价格

    # 3:如果用户输入的商品序号有误,则提示输入有误,并重新输入。
    # 4:用户输入Q或者q,退出程序。

    # goods = [{"name": "电脑", "price": 1999},
    # {"name": "鼠标", "price": 10},
    # {"name": "游艇", "price": 20},
    # {"name": "美女", "price": 998}, ]
    # count = 1
    # lis = [1,2,3,4]
    # for i in goods:
    # print("{} {} {}".format(count, i.get("name"), i.get("price")))
    # count += 1
    # while True:
    # num = input("请输入商品序号:").upper()
    # if num == "Q":
    # break
    # if int(num) in lis:
    # num = int(num)
    # print("商品名称是--{},商品价格是--{}".format(goods[num - 1].get("name"), goods[num - 1].get("price")))
    # else:
    # print("输入有误,请重新输入")
    # print("程序结束!!")

  • 相关阅读:
    c#中Split等分割字符串的几种方法
    js中的null和undefined的区别
    限制CheckBoxList选中的数量
    js中的boolean原始类型和Boolean引用类型
    div漂浮在flash上面
    关于导出excel是经常出现的几个问题
    关于表的合并
    框架
    Js实现类似图片相册左右切换效果
    DNS域名系统
  • 原文地址:https://www.cnblogs.com/kcwxx/p/9273899.html
Copyright © 2011-2022 走看看