字典

dict. 以 {} 表示, 每一项用逗号隔开, 内部元素用 key: value的形式来保存数据

例子: dict.{"JJ":"林俊杰","Jay":"周杰伦"}

查询效率非常高,通过key来查找元素 内部使用key来计算一个内存地址(暂时) , hash 算法 . 要求 key 必须是不可变的数据类型(key 必须是课hash的数据类型)

字典没有切片

字典的增删改查

  1. 新增

    # 第一种方法  直接增加
    dic = {}
    dic["巴萨"] = "梅西"
    dic["尤文"] = "C罗"
    print(dic) # 第二种方法
    dic = {}
    dic.setdefault("切尔西", "阿扎尔") #setfault 设置默认值
    dic.setdefault("切尔西", "德罗巴")
    print(dic)
    # 打印结果是 {"切尔西":"阿扎尔"} 如果存在了key,不会替换掉原来的 如果 value 没有值 打印结果是 None
  2. 删除

    dic = {"巴萨":"梅西", "皇马":"莫德里奇", "曼城":"萨内", "尤文":"C罗", "巴黎":"内马尔"}
    dic.pop("皇马") # 指定key删除 必须有一个参数
    dic.popitem() # 随机删除
    dic.clear() # 清空字典
    del dic["key"] # 删除
  3. 修改和查询

    # 修改
    dic = {"巴萨":"梅西", "皇马":"莫德里奇", "曼城":"萨内", "尤文":"C罗", "巴黎":"内马尔"} dic["key"] = "新value" # 替换掉key 所对应的旧 value dic2 = {"巴萨":"伊涅斯塔", "皇马":"拉莫斯", "曼城":"萨内"}
    dic.update(dic2) # update :更新
    print(dic)
    # 打印结果为 {'巴萨': '伊涅斯塔', '皇马': '拉莫斯', '曼城': '萨内', '尤文': 'C罗', '巴黎': '内马尔'}
    # 查询
    dic = {"巴萨":"梅西", "皇马":"莫德里奇", "曼城":"萨内", "尤文":"C罗", "巴黎":"内马尔"}
    print(dic["曼城"]) # 最直观, 直接用key 当key不存在时会报错 print(dic.get("皇马","value 不在这里") # 如果没有查询到key 会打印出 "value 不在这里" 这句话. 如果没有第二个参数 返回 None . setdefault() # 1. 新增( 先看有没有可以, 如果有就过, 没有执行新增 ) 2. 根据key 把值返回

字典的相关操作

  • dic = {"巴萨":"梅西", "皇马":"莫德里奇", "曼城":"萨内", "尤文":"C罗", "巴黎":"内马尔"}
    # 对字典的遍历
    print(dic.keys()) # 得到一个像列表却不是列表的东西 dict_keys(['巴萨', '皇马', '曼城', '尤文', '巴黎'])
    for key in dic.keys(): # 找到字典中的 key
    print(key) # 打印key
    print(dic[key]) # 打印value for key in dic: # 字典本身是一个可迭代对象,可以直接进行for循环. 找到字典中的 key
    print(key)
    print(dic[key]) for value in dic.values(): # 找到字典中的 value
    print(value) # 打印value print(dic.items()) # 拿到的是key 和 value item 意思是 项
    # 打印结果 : dict_items([('巴萨', '梅西'), ('皇马', '莫德里奇'), ('曼城', '萨内'), ('尤文', 'C罗'), ('巴黎', '内马尔')])
    for item in dic.items():
    print(item) # 打印结果是元组
    ('巴萨', '梅西')
    ('皇马', '莫德里奇')
    ('曼城', '萨内')
    ('尤文', 'C罗')
    ('巴黎', '内马尔')
    print(item[0],item[1])
    巴萨 梅西
    皇马 莫德里奇
    曼城 萨内
    尤文 C罗
    巴黎 内马尔 # 注:
    a, b = (10, 20) # 解构 解包 前面变量的个数和后面解包的个一致
    print(a) # 结果 10
    print(b) # 结果 20 # 根据解构 可将 for item in dic.items(): 简化成下面的形式 for k, v in dic.items(): # 当需要遍历字典. 在操作中设计到key 和 value 的时候.
    print(k)
    print(v)

Python基础篇 -- 字典的更多相关文章

  1. python基础篇-day1

    python基础篇 python是由C语言写的: pass 占位符: del,python中全局的功能,删除内存中的数据: 变量赋值的方法: user,pass = 'freddy','freddy1 ...

  2. Python基础数据类型-字典(dict)

    Python基础数据类型-字典(dict) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版本的哟 ...

  3. python基础篇之进阶

    python基础篇之进阶 参考博客:http://www.cnblogs.com/wupeiqi/articles/5115190.html python种类 1. cpython  使用c解释器生产 ...

  4. python基础篇(六)

    PYTHON基础篇(六) 正则模块re A:正则表达式和re模块案例 B:re模块的内置方法 时间模块time A:时间模块的三种表示方式 B:时间模块的相互转换 随机数模块random A:随机数模 ...

  5. python基础篇(一)

    PYTHON基础篇(一) 变量 赋值 输入,输出和导入 A:输入 B:输出 C:导入 运算符 A:算数运算符 B:比较运算符 C:赋值运算符 D:位运算符 E:逻辑运算符 F:成员运算符 G:身份运算 ...

  6. python基础篇(二)

    PYTHON基础篇(二) if:else,缩进 A:if的基础格式和缩进 B:循环判断 C:range()函数和len()函数 D:break,contiue和pass语句 for,while循环 函 ...

  7. python基础篇(三)

    PYTHON基础篇(三) 装饰器 A:初识装饰器 B:装饰器的原则 C:装饰器语法糖 D:装饰带参数函数的装饰器 E:装饰器的固定模式 装饰器的进阶 A:装饰器的wraps方法 B:带参数的装饰器 C ...

  8. python基础篇(四)

    PYTHON基础篇(四) 内置函数 A:基础数据相关(38) B:作用域相关(2) C:迭代器,生成器相关(3) D:反射相关(4) E:面向对象相关(9) F:其他(12) 匿名函数 A:匿名函数基 ...

  9. 面试题之第一部分(Python基础篇) 80题

    第一部分(python基础篇)80题 为什么学习Python?==*== # 1. python应用于很多领域,比如后端,前端,爬虫,机器学习(人工智能)等方面,几乎能涵盖各个开发语言的领域,同时它相 ...

随机推荐

  1. E20180527-hm

    percolate vi. 渗透; 滤; 渗入; (思想等) 渗透

  2. 51nod1093(推公式&找規律)

    題目鏈接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1093 題意:中文題誒- 思路:xjb 一開始死活想不出怎麼將一 ...

  3. IT兄弟连 JavaWeb教程 JSP内置对象经典面试题

    1.请说明cookie.request.session.application的作用域和声明周期? 并说明它们适用与什么场景? request的生命周期是一次请求.可以用于JSP表单提交数据. ses ...

  4. BZOJ3224普通平衡树

    洛谷题面链接 很早就过了,太久没打了,原本是在noip前用来练emacs的手感的. noip炸了,就滚回来更博客了(安排的计数任务刷不动,学不会容斥,打发时间...) 众所周知,splay是个好算法, ...

  5. idea | SpringBoot项目热加载

    第一步: 在pom文件添加依赖: <dependency> <groupId>org.springframework.boot</groupId> <arti ...

  6. C# 基础之密封类

    C#密封类 一.密封类 1. 密封类的定义 如果我们不希望自己编写的类被继承:如果有的类已经没有再被继承的必要,这时,我们可以使用sealed修饰符在类中进行声明,以达到该类不能派生其它类的目的,该类 ...

  7. AKOJ-1265-输出二叉树

    链接:https://oj.ahstu.cc/JudgeOnline/problem.php?id=1265 题意: 我们知道二叉树的先序序列和中序序列或者是中序和后序能够唯一确定一颗二叉树.现在给一 ...

  8. 洛谷 P2662 牛场围栏

    做法是这样的: 首先暴力把所有可能的边长搞出来..(当然<=0的不要) 排序边长+去重, 当且仅当可行边长里面有1时,任何长度都能取到,输出-1 当且仅当所有可行边长的gcd大于1时,不能取到的 ...

  9. 089 Gray Code 格雷编码

    格雷编码是一个二进制数字系统,在该系统中,两个连续的数值仅有一个位数的差异.给定一个代表编码总位数的非负整数 n,打印格雷码序列.格雷码序列必须以0开头.例如, 给定 n = 2, 返回 [0,1,3 ...

  10. 17999 Light-bot 模拟 + kmp求循环节

    http://acm.scau.edu.cn:8000/uoj/mainMenu.html 17999 Light-bot 时间限制:1000MS  内存限制:65535K 提交次数:0 通过次数:0 ...