Day5--Python--字典
字典
1.什么是字典
dict. 以{}表示,每一项用逗号隔开,内部元素用key:value的形式来保存数据
{'jj':'林俊杰','jay':'周杰伦'}
查询效率非常高,通过key来查找元素
内部使用key来计算一个内存地址,hash(哈希)算法. key必须是不可变的数据类型(key 必须是可hash的类型)
可哈希就是不可变 dic = {"jj":"林俊杰", "jay":"周杰伦","tz":"陶喆", 1:"哈哈", (1,2,3):"胡辣汤"} # unhashable type: 'list' 所以元组可以做key,列表 不可以
print(dic) 2.字典的增删改查
1.字典的新增:
dict[新key] = value
dict.setdefault() dic = {}
dic['徐峥'] = '人在囧途' # 直接用key往里面存数据即可
dic['黄渤'] = '疯狂的石头'
dic['黄渤'] = '摸金校尉' #如果key已经存在,那么会替换掉原来的value,修改 dic.setdefault('黄秋生','')
dic.setdefault('黄秋生','无间道') #如果存在了key,不会执行新增 print(dic)
print(dic.setdefault('黄秋生')) #none 2.删除
pop(key)
popitem() 删除任意键值对,由python内部机制指定
clear() 清空
del dict[key] dic = {"黄日华": "天龙八部", "吕颂贤": "笑傲江湖", "苏有朋": "倚天屠龙记", "六小龄童": "西游记"}
dic.pop("吕颂贤") # 指定key删除
dic.popitem() # 由python机制指定删除任意键值对
del dic["黄日华"] # 删除
dic.clear() # 清空字典
print(dic)
dic = dict.fromkeys('abcde',111)
print(dic) # {'a': 111, 'b': 111, 'c': 111, 'd': 111, 'e': 111}
ret = dic.get('a')
print(ret)
ret2 = dic.get('g')
print(ret2) # None
ret3 = dic.get('g', '没找到')
print(ret3) # 没找到
3.修改
dict['key'] = '修改后的内容'
update() dic = {}
dic2 = {}
dic.update(dic2) #替换和新增 dic2 替换dic1中key相同的内容,增加dic没有的内容,dic中不重合的内容不变
print(dic) dic = {"刘能": "王小利", "赵四": "刘晓光", "王木生": "范伟", "谢大脚": "于月仙", "李大国": "小鬼"}
# dic['王木生'] = "刘伟"
dic2 = {"刘能": "大阳哥", "赵四": "github", "王木生": "汪峰", "谢大脚": "冯提莫", "王大拿": "金老板"}
dic.update(dic2)
print(dic) 4.查询
1.用key直接查询 dict[key]
2.get(key,如果key不存在返回的数据)
3.setdefault() #1.执行新增流程 2.查询结果 print(dic['key']) #当key不存在,则报错 #get方法
print(dic.get('key','没查到所需信息')) #print(dic.get('key'))没有key,返回None,或返回第二项输入的内容
setdefault() 1.新增(先看看有没有key,如果有就过,如果没有,执行新增
dic = {}
dic['红'] = '红花'
v = dic.setdefault('橙', '橙光')
v2 = dic.setdefault('红', '大红花') #由于已经存在了key,所以不执行新增,直接查询结果
print(v2) # 查询
dic = {'刘能': '大阳哥', '赵四': 'github', '王木生': '汪峰', '谢大脚': '冯提莫', '李大国': '小鬼', '王大拿': '金老板'}
# 1. 最直观。 直接用key
print(dic['周杰伦']) # 当这个key不存在的时候会报错
# 2. get方法
print(dic.get("谢大脚", "周杰伦不在这里")) # 没有key. 返回None
# 3. setdefault() 1. 新增(先看有没有key, 如果有就过, 如果没有,执行新增) 2.根据key把值返回
dic = {}
dic["盖伦"] = "德玛西亚之力"
value = dic.setdefault("菲奥娜", "无双剑姬") # 新增
value2 = dic.setdefault("盖伦", "刘伟") # 由于已经存在了key。 所以新增不执行。 直接查询结果
value3 = dic.setdefault("薇恩", "坑") print(value3)
print(dic) 5.操作
1.keys()获取所有键 这个返回的不是列表,很像列表
2.values()获取所有的值
3.items()获取所有的键值对. 返回的是元组
解构,直接把元组或者列表中的数据拿出来.
a,b,c = (a1,b1,c1) 必须一一对应 6.遍历字典
在循环字典时,不要增加或删除此字典的键值对
for key in dict:
dict[key] for k, v in dict.items():
print(k, v) dic = {"汪峰": "大陆音乐半壁江山", "周杰伦": "亚洲音乐天王", "罗志祥": "亚洲舞王"} 对字典的遍历
print(dic.keys()) # dict_keys(['汪峰', '周杰伦', '罗志祥']) 像列表但不是列表
for key in dic.keys():
print(key) # 拿到key
print(dic[key]) # 拿到value print(dic.values())
for value in dic.values():
print(value) 也可以遍历字典
[('汪峰', '大陆音乐半壁江山'), ('周杰伦', '亚洲音乐天王'), ('罗志祥', '亚洲舞王')]
print(dic.items()) # 拿到的是key和value
for k, v in dic.items(): # 当需要遍历字典. 在操作中涉及到key和value的时候.
print(k) # 元组
print(v) 字典本身是一个可迭代对象,可以直接进行for循环
for el in dic: # 直接拿到key
print(el)
print(dic[el]) 前面的变量的个数和后面解包的个数一致
a, b = (10, 20) # 解构, 解包 可以是 10, 20 [10,20]
print(a)
print(b) 3.字典嵌套
wf = {
"name": "汪峰",
"age": 48,
"成名曲": "春天里",
"wife": {
"name": "章子怡",
"age": 39,
"工作": "演员"
},
"children":[
{"num": "001", "name": "汪一", "hobby": "唱歌"},
{"num": "002", "name": "汪二", "hobby": "演戏"} # wf['children'][1]['name']
]
} wf['wife']['age'] = wf['wife']['age'] + 10
print(wf) 4. fromkeys
dic = dict.fromkeys([1, 2, 3], '')
dic[1] = 2
print(dic)
print(id(dic[1]))
print(id(dic[2]))
print(id(dic[3])) '''
{1: 2, 2: '111', 3: '111'}
1410100272
2250339877304
2250339877304
'''
Day5--Python--字典的更多相关文章
- DAY5(PYTHON) 字典的增删改查和dict嵌套
一.字典的增删改查 dic={'name':'hui','age':17,'weight':168} dict1={'height':180,'sex':'b','class':3,'age':16} ...
- Python字典和集合
Python字典操作与遍历: 1.http://www.cnblogs.com/rubylouvre/archive/2011/06/19/2084739.html 2.http://5iqiong. ...
- python 字典排序 关于sort()、reversed()、sorted()
一.Python的排序 1.reversed() 这个很好理解,reversed英文意思就是:adj. 颠倒的:相反的:(判决等)撤销的 print list(reversed(['dream','a ...
- python字典中的元素类型
python字典默认的是string item={"browser " : 'webdriver.irefox()', 'url' : 'http://xxx.com'} 如果这样 ...
- python字典copy()方法
python 字典的copy()方法表面看就是深copy啊,明显独立 d = {'a':1, 'b':2} c = d.copy() print('d=%s c=%s' % (d, c)) Code1 ...
- python 字典实现类似c的switch case
#python 字典实现类似c的switch def print_hi(): print('hi') def print_hello(): print('hello') def print_goodb ...
- python字典的常用操作方法
Python字典是另一种可变容器模型(无序),且可存储任意类型对象,如字符串.数字.元组等其他容器模型.本文章主要介绍Python中字典(Dict)的详解操作方法,包含创建.访问.删除.其它操作等,需 ...
- Python 字典(Dictionary)操作详解
Python 字典(Dictionary)的详细操作方法. Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型. 一.创建字典 字典由键和对应值成对组成.字 ...
- Python 字典(Dictionary) get()方法
描述 Python 字典(Dictionary) get() 函数返回指定键的值,如果值不在字典中返回默认值. 语法 get()方法语法: dict.get(key, default=None) 参数 ...
- Python 字典(Dictionary) setdefault()方法
描述 Python 字典(Dictionary) setdefault() 函数和get()方法类似, 如果键不已经存在于字典中,将会添加键并将值设为默认值. 语法 setdefault()方法语法: ...
随机推荐
- 生成统计数据并导出Excel
需求:看如下表格的统计需求 生产调度中心部门需要从IT技术部门得到这些统计数据 步骤: (1)获取所有的子公司列表 (2)遍历所有的子公司,获取每个子公司的库存信息 (3)遍历所有的库存信息,并对库存 ...
- mysql从入门到精通
解决MySQL Got a packet bigger than 'max_allowed_packet' bytes 问题在一次性向mysql插入的数据过大,可在my.ini中修改max_allow ...
- EmpireCMS的使用
1.下载安装empirecms 下载完成后解压将upload目录整体上传到服务器,并更名为empirecms_test 更改目录文件的权限: chmod -R 777 empirecms_test 配 ...
- mysql group by 对多个字段进行分组
在平时的开发任务中我们经常会用到MYSQL的GROUP BY分组, 用来获取数据表中以分组字段为依据的统计数据.比如有一个学生选课表,表结构如下: Table: Subject_Selection S ...
- jedis集群版应用
1.pom文件添加依赖: 2.创建配置文件 <!-- jedis集群版配置(JedisCluster通过构造传参(2个参数)) --> <bean id="redisCli ...
- 官网下载旧版本jdk,老版本jdk,jdk1.7,jdk1.8
1.进入中文oracle官网(不是国内官网下载速度超级慢): http://www.oracle.com/technetwork/cn/indexes/downloads/index.html 2.进 ...
- 学习 Spring (七) Resource
Spring入门篇 学习笔记 Resource: Spring 针对资源文件的统一接口 UrlResource: URL 对应的资源,根据一个 URL 地址即可构建 ClassPathResource ...
- 转载:关于JESD204B转换器与FPGA匹配的设计关键点
http://www.dzsc.com/data/2014-11-27/107442.html 随着更多的模数转换器(ADC)和数模转换器(DAC)支持最新的JESD204B串行接口标准,出现了FPG ...
- struts2 核心过滤器的配置
<!-- struts2 过滤器核心配置--> <filter> <filter-name>struts2</filter-name> <filt ...
- hdu-1251(字典树)
字典树模板题. ps:数组要开大,40w左右才行,不然疯狂re 代码: #include<iostream> #include<algorithm> #include<c ...