200 ? "200px" : this.width)!important;}
-->

介绍

dict(dictionary),在其他语言中也称为map,使用键-值(key-value)存储。set和dict类似,也是一组key的集合,但不存储value。字典和set的key都是不允许重复且key不能是列表。

 
 
一、dict(字典的缩写)
字典和前面讲的list(列表)很相似,但是list不存在value,同时字典也和xml、json很像。字典使用一对大括号表示
1.创建字典表
创建一个学生分数字典
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([])的更多相关文章

  1. Python dict operation introduce

    字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式如下所示: d = ...

  2. Python dict(或对象)与json之间的互相转化

    Python dict(或对象)与json之间的互相转化 原文转载自 1.JSON:JavaScript 对象表示法,是轻量级的文本数据交换格式,独立于语言,平台 2.JSON 语法规则 数据在名称/ ...

  3. python & dict & switch

    python & dict & switch python 中是没用switch语句的,这应该是体现python大道至简的思想,python中一般多用字典来代替switch来实现. # ...

  4. Python dict() 函数

    Python dict() 函数  Python 内置函数 描述 dict() 函数用于创建一个字典. 语法 dict 语法: class dict(**kwarg) class dict(mappi ...

  5. python dict乱码如何解决

    定义字典并直接输出,结果输出结果中文是乱码展示 d={'name':'lily','age':18,'sex':'女','no':1121} print d 输出结果: {'age': 18, 'no ...

  6. 转:python dict按照value 排序

    我们知道Python的内置dictionary数据类型是无序的,通过key来获取对应的value.可是有时我们需要对dictionary中 的item进行排序输出,可能根据key,也可能根据value ...

  7. (翻译)如何对python dict 类型按键(keys)或值(values)排序

    如何对dict类型按键(keys)排序(Python 2.4 或更高版本): mydict = {'carl':40, 'alan':2, 'bob':1, 'danny':3} for key in ...

  8. Python dict 按键和值排序

    python 字典(dict)的特点就是无序的,按照键(key)来提取相应值(value),如果我们需要字典按值排序的话,那可以用下面的方法来进行:1 下面的是按照value的值从大到小的顺序来排序. ...

  9. Python dict和set的实现原理

    在python的dict中间进行查找某个key操作时,查找所需时间不会随着dict中键值对数量增多而变长,(时间复杂度为O(1))但是list中就会(时间复杂度为O(N)),这是因为list查询实现的 ...

随机推荐

  1. C#委托的介绍(delegate、Action、Func、predicate)【转】

    转自 http://www.cnblogs.com/akwwl/p/3232679.html 委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递.事件是一种特殊的委托. 1 ...

  2. 证明:寝室分配问题是NPC问题

    P.NP.NPC.NP-hard P:多项式时间能够解决的问题的集合,比如最短路径问题是集合P的一个元素,而最短路径问题本身又是一个集合,因此P是集合的集合. NP:多项式时间内能够验证的问题的集合. ...

  3. hdu 4635 Strongly connected(强连通)

    考强连通缩点,算模板题吧,比赛的时候又想多了,大概是不自信吧,才开始认真搞图论,把题目想复杂了. 题意就是给你任意图,保证是simple directed graph,问最多加多少条边能使图仍然是si ...

  4. HDU 4632 Palindrome subsequence (区间DP)

    题意 给定一个字符串,问有多少个回文子串(两个子串可以一样). 思路 注意到任意一个回文子序列收尾两个字符一定是相同的,于是可以区间dp,用dp[i][j]表示原字符串中[i,j]位置中出现的回文子序 ...

  5. LeetCode Linked List Cycle 单链表环

    题意:给一个单链表,判断其是否出现环! 思路:搞两个指针,每次,一个走两步,另一个走一步.若有环,他们会相遇,若无环,走两步的指针必定会先遇到NULL. /** * Definition for si ...

  6. Java [Leetcode 136]Single Number

    题目描述: Given an array of integers, every element appears twice except for one. Find that single one. ...

  7. group by的使用

    1.概述 2.原始表 3.简单Group By 4.Group By 和 Order By 5.Group By中Select指定的字段限制 6.Group By All 7.Group By与聚合函 ...

  8. 获取某月第一天,最后一天的sql server脚本 【转】http://blog.csdn.net/chaoowang/article/details/9167969

    这是计算一个月第一天的SQL 脚本:    SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) --当月的第一天 SELECT DATEADD(mm, DA ...

  9. UI特效--Android利用ViewFlipper实现屏幕切换动画效果

    .屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面.2.介绍ViewFilpper类ViewFl ...

  10. [OFBiz]开发 三

    1. Debug不要在Eclipse中使用Ant来启动ofbiz, 因为在Eclipse中无法kill掉Ant的进程,而ofbiz又没有提供stop的方法.(有一个hook shutdown的方法,但 ...