zoukankan      html  css  js  c++  java
  • 基础数据类型及操作

    字典dict

    字典(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没有要求.可以保存任意类型的数据

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

     字典的增删改查和其他相关操作

    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)

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

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

    value1 = dic["name"]  # 没有会报错
    print(value1)
    
    value2 = dic.get("djffdsafg","默认返回值")  # 没有可以返回设定的返回值
    print(value2)

    其他相关操作

    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])

    练习

    dic = {
    'name':['alex',2,3,5],
    'job':'teacher',
    'oldboy':{'alex':['python1','python2',100]}
    }
    # 1,将name对应的列表追加一个元素’wusir’。
    dic['name'].append("wusir")
    print(dic)
    # 2,将name对应的列表中的alex首字母大写。
    dic['name'][0] = dic['name'][0].capitalize()
    print(dic)
    # 3,oldboy对应的字典加一个键值对’老男孩’,’linux’。
    dic['oldboy']['老男孩'] = 'linux'
    print(dic)
    # 4,将oldboy对应的字典中的alex对应的列表中的python2删除。
    dic["oldboy"]['alex'].remove('python2')
    print(dic)
  • 相关阅读:
    读spring Micro-Service tats收获
    读spring Micro-Service tats收获
    读spring Micro-Service tats收获
    读Software Entity Architektur收获
    读Software Entity Architektur收获
    读Software Entity Architektur收获
    mvc案例
    11.16
    11.15
    11.13
  • 原文地址:https://www.cnblogs.com/caisong/p/9140407.html
Copyright © 2011-2022 走看看