zoukankan      html  css  js  c++  java
  • 基本数据类型(dict)

    目录:

      1.字典的简单介绍

      2.字典增删改查和其他操作

      3.字典的嵌套

    一.字典的简单介绍

      字典(dict)是python中唯一的一个映射类型,他是以{}括起来的键值对组成,在dict中key是唯一的,在保存的时候,根据key类计算出一个地址然后将key-value保存在这个地址中这种算法被称作hash算法,所以,切记,在dict中存储的key-value的key必须是可hash的,那么可哈希就意味着不可变,这个是为了能准确的聚酸内存地址而规定

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

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

    语法:

      {key1:value1,key2:value2......}
    注意:key必须是不可变(可哈希)的,value没有要求,可以保存任意数据类型的数据

    # 合法 
    dic = {123: 456, True: 999, "id": 1, "name": 'sylar', "age": 18, "stu": ['帅 哥', '美⼥女'], (1, 2, 3): '麻花藤'} 
    print(dic[123]) 
    print(dic[True]) 
    print(dic['id']) 
    print(dic['stu']) 
    print(dic[(1, 2, 3)]) 
    
    # 不合法 # 
    dic = {[1, 2, 3]: '周杰伦'}   # list是可变的. 不能作为key 
    # dic = {{1: 2}: "哈哈哈"}     
    # dict是可变的. 不不能作为key 
    dic = {{1, 2, 3}: '呵呵呵'}    # set是可变的, 不能作为key

    dict保存的数据不是按照我们添加进去的顺序保存的,是按照hash表的顺序保存的,而hash表不是连续的,所以不能进行切片工作,他只能key来获取dict中的数据

    1.增加

    dic = {} 
    dic['name'] = '周润发'     # 如果dict中没有出现这个key, 就会新增一个key-value的组 合进dict 
    dic['age'] = 18 
    print(dic) 
    
    # 如果dict中没有出现过这个key-value. 可以通过setdefault设置默认值 
    dic.setdefault('李嘉诚')   # 也可以往里面设置值. 
    dic.setdefault("李嘉诚", "房地产")  # 如果dict中已经存在了. 那么setdefault将不会 起作用 
    print(dic)

    2.删除

    ret = dic.pop("jay") 
    print(ret) 
    
    del dic["jay"] 
    print(dic) 
    
    # 随机删除. 
    ret = dic.popitem() 
    
    # 清空字典中的所有内容 
    dic.clear()

    3.修改

    dic = {"id": 123, "name": 'sylar', "age": 18} 
    dic1 = {"id": 456, "name": "麻花藤", "ok": "wtf"} 
    dic.update(dic1)    # 把dic1中的内容更新到dic中. 如果key重名. 则修改替换. 如果不存 在key, 则新增. 
    print(dic) 
    print(dic1)

    4.查询

    查询一般用key来查找具体的数据

    print(dic['name']) 
    
    # print(dic['sylar'])     # 报错 
    
    print(dic.get("ok"))
    
    print(dic.get("sylar"))      # None 
    
    print(dic.get("sylar", "⽜牛B"))   # 牛B

    5.其他相关操作

    dic = {"id": 123, "name": 'sylar', "age": 18, "ok": "科比"} 
    print(dic.keys())   # dict_keys(['id', 'name', 'age', 'ok']) 不用管它是什么.当 成list来用就行 
    for key in dic.keys():
        print(key) 
    
    print(dic.values())     # dict_values([123, 'sylar', 18, '科⽐比']) 一样. 也当 list来⽤ for value in dic.values():
        print(value) 
    print(dic.items())  # dict_items([('id', 123), ('name', 'sylar'), ('age', 18), ('ok', '科⽐比')]) 这个东西也是list. 只不过list中装的是tuple 
    for key, value in dic.items():  # ?? 这个是解构    
        print(key, value) 
    
    # 解构 
    a, b = 1, 2 
    print(a, b) 
    
    (c, d) = 3, 4 
    print(c, d) 
    
    e, f = [1, 2, 3]    # 解构的时候注意数量必须匹配 
    print(e, f)

    三.字典的嵌套

    # 字典的嵌套 
    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])

    练习:

    dic1 = {
        'name':['alex',2,3,5],
        'job':'teacher',
        'oldboy':{'alex':['python1','python2',100]}
        } 
    1,将name对应的列列表追加⼀一个元素’wusir’。 
    2,将name对应的列列表中的alex⾸首字⺟母⼤大写。 
    3,oldboy对应的字典加⼀一个键值对’⽼老老男孩’,’linux’。
    4,将oldboy对应的字典中的alex对应的列列表中的python2删除
  • 相关阅读:
    使用jQuery插件时避免重复引入jquery.js文件
    读书笔记《集体智慧编程》Chapter 2 : Make Recommendations
    数据挖掘学习07 《数据挖掘导论》第二章:数据
    推荐2款在线Ascii画图工具
    数据挖掘学习08 实验:使用R评估kmeans聚类的最优K
    数据挖掘学习05 使用R对文本进行hierarchical cluster并验证结果
    Apache alias目录配置
    数据挖掘学习06 《数据挖掘导论》导读
    Unix网络编程 3rd vol1 读书笔记
    关于Xcode
  • 原文地址:https://www.cnblogs.com/LLBFWH/p/9890589.html
Copyright © 2011-2022 走看看