python dict{}和set([])
200 ? "200px" : this.width)!important;}
-->
介绍
dict(dictionary),在其他语言中也称为map,使用键-值(key-value)存储。set和dict类似,也是一组key的集合,但不存储value。字典和set的key都是不允许重复且key不能是列表。
s={'stu1':80,'stu2':90,'stu3':60}
2.查询
查询stu1的分数
>>> s['stu1']
80
>>>
3.修改value
>>> s['stu1']=50
>>> s
{'stu3': 60, 'stu2': 90, 'stu1': 50}
4.增加key
例如增加一个代表学生stu4-stu7的key-value
>>> s['stu4-7']=[40,80,50,60]
>>> s
{'stu3': 60, 'stu2': 90, 'stu1': 50, 'stu4-7': [40, 80, 50, 60]}
注意:key不能是变量(python里面的变量不太容易理解,就简单的理解key不能是list就行),但是value可以是变量(python里面的),value可以是常量、字符串、list、tuple等
>>> s['stu8-9']=(80,50)
>>> s
{'stu3': 60, 'stu8-9': (80, 50), 'stu2': 90, 'stu1': 50, 'stu4-7': [40, 80, 50, 60]}
读取stu8的分数
>>> s['stu8-9'][0]
80
>>>
5.删除key
要删除一个key,用pop(key)
方法,对应的value也会从dict中删除
例如:删除key"stu1"
>>> s.pop('stu1')
50
>>> s
{'stu3': 60, 'stu8-9': (80, 50), 'stu2': 90, 'stu4-7': [40, 80, 50, 60]}
>>> s['stu1']
Traceback (most recent call last):
File "<pyshell#14>", line 1, in <module>
s['stu1']
KeyError: 'stu1'
>>>
6.判断一个key是否存在
方法1:直接打印输出,如果key不存在会返回错误
>>> s['stu1']
Traceback (most recent call last):
File "<pyshell#14>", line 1, in <module>
s['stu1']
KeyError: 'stu1'
>>>
方法2:通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value:
s.get('stu1')
可以用print打印出None
>>> print (s.get('stu1'))
None
>>>
可以自己指定key不存在返回的值,例如返回1,但是返回值必须是整形
>>> s.get('stu1',1)
1
方法3:通过in
判断key是否存在,不存在返回Flase
>>> 'stu1' in s
False
>>> 'stu2' in s
True
二、set([])
set和dict类似,也是一组key的集合,但不存储value;set和dict一样key不允许是list且key不能重复。
1.创建set
要创建一个set,需要提供一个list作为输入集合,注意set的固定格式,set([]),在set()中加入list
>>> se=set(['a','b','c'])
>>> se
{'b', 'c', 'a'}
注意:list中的每一个元素都是一个key,但是元素不能是list可以是常量、字符串、tuple、浮点型
2.读取key
>>> se
{'b', 'c', 'a'}
set不支持索引,所以没办法像list和tuple那样根据索引获取指定的key,比如se[0]会返回错误
4.增加key
通过add(key)
方法可以添加元素到set中,可以重复添加,但不会有效果
>>> se.add('d')
>>> se
{'b', 'c', 'd', 'a'}
>>>
5.删除key
通过remove(key)
方法可以删除元素
>>> se.remove('c')
>>> se
{'b', 'd', 'a'}
>>>
6.设置一个list key
>>> se.add(['e','f'])
Traceback (most recent call last):
File "<pyshell#74>", line 1, in <module>
se.add(['e','f'])
TypeError: unhashable type: 'list'
返回错误:没有对应的list哈希表
注意:这里的['e','f']指的是一个元素(key),只不过它是list元素,set([])中的key不支持list.
总结
从dict{}和set([])的返回key可以发现它们是没有固定的顺序的。但是key不能是list。dict的value可以是任何已知的类型值。
备注: 作者:pursuer.chen 博客:http://www.cnblogs.com/chenmh 本站点所有随笔都是原创,欢迎大家转载;但转载时必须注明文章来源,且在文章开头明显处给明链接。 《欢迎交流讨论》 |
python dict{}和set([])的更多相关文章
- Python dict operation introduce
字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式如下所示: d = ...
- Python dict(或对象)与json之间的互相转化
Python dict(或对象)与json之间的互相转化 原文转载自 1.JSON:JavaScript 对象表示法,是轻量级的文本数据交换格式,独立于语言,平台 2.JSON 语法规则 数据在名称/ ...
- python & dict & switch
python & dict & switch python 中是没用switch语句的,这应该是体现python大道至简的思想,python中一般多用字典来代替switch来实现. # ...
- Python dict() 函数
Python dict() 函数 Python 内置函数 描述 dict() 函数用于创建一个字典. 语法 dict 语法: class dict(**kwarg) class dict(mappi ...
- python dict乱码如何解决
定义字典并直接输出,结果输出结果中文是乱码展示 d={'name':'lily','age':18,'sex':'女','no':1121} print d 输出结果: {'age': 18, 'no ...
- 转:python dict按照value 排序
我们知道Python的内置dictionary数据类型是无序的,通过key来获取对应的value.可是有时我们需要对dictionary中 的item进行排序输出,可能根据key,也可能根据value ...
- (翻译)如何对python dict 类型按键(keys)或值(values)排序
如何对dict类型按键(keys)排序(Python 2.4 或更高版本): mydict = {'carl':40, 'alan':2, 'bob':1, 'danny':3} for key in ...
- Python dict 按键和值排序
python 字典(dict)的特点就是无序的,按照键(key)来提取相应值(value),如果我们需要字典按值排序的话,那可以用下面的方法来进行:1 下面的是按照value的值从大到小的顺序来排序. ...
- Python dict和set的实现原理
在python的dict中间进行查找某个key操作时,查找所需时间不会随着dict中键值对数量增多而变长,(时间复杂度为O(1))但是list中就会(时间复杂度为O(N)),这是因为list查询实现的 ...
随机推荐
- asp.net清除页面缓存防止同时登录
//清除页面缓存,防止页面回退重复提交数据 在页面里做以下设置就可以使页面的缓存失效,每次都需要获取新页面. Response.Cache.SetCacheability(System.Web.Htt ...
- git - svn 平滑到 git
1. 建立自己的git仓库,需要是空git仓库 2. checkout 你的 git仓库 3. svn忽略.git文件,忽略.git .gitignore 4. 把 .git文件拷到你的 svn仓库 ...
- Mac 配置jdk
1.打开终端,开始操作 cd ~touch.bash_profile vi .bash_profile 2.在此文本中添加以下内容 export JAVA_HOME=/Library/Java/Jav ...
- MySQL基础之第5章 操作数据库
假设已经登录 mysql-h localhost -uroot -proot 5.1.显示.创建.删除数据库 show databases; 显示所有的数据库 create database ...
- 2016计蒜之道复赛 百度地图的实时路况 floyd+cdq分治
链接:https://nanti.jisuanke.com/t/11217 奉上官方题解: 枚举 d(x , y , z) 中的 y,把 y 从这个图中删去,再求这时的全源最短路即可,使用 Floyd ...
- POJ 2728 Desert King 01分数规划,最优比率生成树
一个完全图,每两个点之间的cost是海拔差距的绝对值,长度是平面欧式距离, 让你找到一棵生成树,使得树边的的cost的和/距离的和,比例最小 然后就是最优比例生成树,也就是01规划裸题 看这一发:ht ...
- vc编译器 msvcr.dll、msvcp.dll的含义和相关错误的处理
转自:http://blog.csdn.net/sptoor/article/details/6203376 很久没有写程式设计入门知识的相关文章了,这篇文章要来谈谈程式库 (Library) 连结, ...
- 线性模型(3):Logistic Regression
此笔记源于台湾大学林轩田老师<机器学习基石><机器学习技法> (一)Logistic Regression 原理 对于分类问题,假设我们想得到的结果不是(x属于某一类)这种形式 ...
- ubuntu 14.04 允许root 登录
在/etc/lightdm/lightdm.conf里添加一下两句: greeter-show-manual-login=true allow-guest=false
- “大数据讲师”、“Hadoop讲师”、“Spark讲师”、“云计算讲师”、“Android讲师”
王家林简介 Spark亚太研究院院长和首席专家,中国目前唯一的移动互联网和云计算大数据集大成者. 在Spark.Hadoop.Android等方面有丰富的源码.实务和性能优化经验.彻底研究了Spark ...