Python内置了字典:dict的支持,dict全称dictionary;

表达式为dict{key,value} 使用键值对来存储数据

eg: 使用dict来存储姓名和分数

d = {'bob':20,'lisa':80,'tom':90}
>>>d
{'bob':20,'lisa':80,'tom':90}

dict的查找速度比list快,dict叫做字典,从名称上就能看出来,就行我们查字典,以关键词查找;

而list的每个元素都要遍历一遍才能查找到自己想要的数据

如何访问key得到value?

查找的key不存在的时候,会报错keyerror

>>>d['bob']
20
>>>d['mm']
....
.....
keyerror

要避免keyerror,可以先判断key是否存在,还有dict提供的get()方法

>>>'bob' in d
Ture
>>>'jeny' in d
False
#dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value:
>>>d.get('bob')
20
>>>d.get('lili') #不存在,返回None
#返回自己指定的错误返回值
>>>d.get('lili',5)
5

如何在dict中插入键值对?

d = {'bob':20,'lisa':80,'tom':90}
#通过key插入
d['jerry'] = 65
>>>d
{'bob':20,'lisa':80,'tom':90,'jerry':65}

当插入的键重复后,前者的value会被覆盖,python是动态语言,变量也是如此,后者覆盖前者。

要删除一个key,用pop(key)方法,对应的value也会从dict中删除:

d = {'bob':20,'lisa':80,'tom':90}
>>>d.pop('bob')
20
>>>d
['lisa':80,'tom':90]

使用for循环遍历dict。

items()方法,以列表返回可遍历的(键, 值) 元组数组。

d = {'score':80,'name':'jess','class':2}
#只拿出key
for k in d:
print(k)
score
name
class #只拿出value,使用方法d.values()
for y in d.values():
  print(y)
80
jess
2 #同时拿出key和value
for k,v in d.items():
  print(k,v)
score 80
name jess
class 2

set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key.

写法为:set = ([x,y,z])   内含一个list作为输入集,写法看起来就像tuple内包含了一个list

如果set()内包含了重复的元素,set会自动剔除掉

s = ([1, 2, 3,3])
>>>s
[1,2,3]

add()方法添加元素到set内,remove()方法进行删除。

add()(待定,使用add方法添加时报错,list不存在add()方法,IDE会提示append()方法,可以正常添加)

insert()方法同list操作,正常。

s = ([1,2,3])
#>>>s.add(4)
#>>>s
#[1,2,3,4]
>>>s.remove(2)
>>>s
[1,3,4]

set的其他方法如下:

clear()清空set所有元素

name = set(['Tom','Lucy','Ben'])
name.clear()
print(name) #输出:set()

copy()复制set到另一个set

name = set(['Tom','Lucy','Ben'])
new_name = name.copy()
print(new_name) #输出:{'Tom', 'Lucy', 'Ben'}

difference()比较两个或者多个set,剔除重复元素,只要两者之间有重复,就删除。

n1 = set([2,3,4,5])
n2 = set([3,4])
n3 = set([2])
n = n1.difference(n2,n3)
print(n) #输出:{5}
#返回A集合里面,在B和C集合中没有的元素,并生成新的集合

difference_update(删除A集合里面,在B集合中存在的元素。)

A = set([2,3,4,5])
B = set([4,5])
A.difference_update(B)
print(A) #输出:{2, 3}

##########discard(移除元素) shell里面也没有提示这个,所以暂时不要使用,   用remove()就行

n = set([2,3,4])
n.discard(3)
print(n) #输出:{2, 4}

pop()随机删除一个元素。

s = ([1,2,3,4,5])
>>>s.pop()
5

sort()正序排序

s = ([2,9,8,6])
>>>s.sort()
[2,6,8,9]

reverse()倒序排序

s = ([1,2,3,4,5])
>>>s.reverse()
[5,4,3,2,1]

目前shell就提示这么多,改动的话再编辑。

Python的字典dict和set的更多相关文章

  1. python基础——字典dict

    1.概念: (1)字典dict,是一系列的键—值对.每个键key都和一个值value相映射.(字典是python中唯一的映射类型.) (2)每一项item,是一个键值对key—value对. (3)键 ...

  2. python基础——字典(dict)

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

  3. python中字典dict的操作

    字典可存储任意类型的对象,由键和值(key - value)组成.字典也叫关联数组或哈希表. dict = {' , 'C' : [1 , 2 , 3] } dict['A'] = 007 # 修改字 ...

  4. Python中字典dict

    dict字典 字典是一种组合数据,没有顺序的组合数据,数据以键值对形式出现 # 字典的创建 # 创建空字典1 d = {} print(d) # 创建空字典2 d = dict() print(d) ...

  5. python基础-字典dict

    字典-dict 用途: 定义方法:通过{} 来存储数据,通过key:value (键值对)来存储数据,每个键值对通过逗号分隔.在键值对中,key 是不可变的数据类型,value 是任意数据类型 def ...

  6. python数据类型:字典dict常用操作

    字典是Python语言中的映射类型,他是以{}括起来,里面的内容是以键值对的形式储存的: Key: 不可变(可哈希)的数据类型.并且键是唯一的,不重复的. Value:任意数据(int,str,boo ...

  7. Python基础:字典(dict)与集合(set)

    查找场景下与列表的性能对比 字典与集合之所以高效的原因是:内部结构都是一张哈希表. 平均情况下插入.查找和删除的时间复杂度为 O(1). 假设有数量100,000的产品列表: import time ...

  8. Python操作字典(dict)

    一.字典定义 >>> dict={} 二.字典元素添加 >>> dict['性别']='男' >>> dict {'性别': '男'} >& ...

  9. python之字典(dict)

    字典:一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型. 字典由键和对应值成对组成 {key:value,key1,value1}, 例如: dic = {'中国': '汉语 ...

随机推荐

  1. UVA12558 埃及分数

    #include<iostream> #include<cstdio> #include<set> #include<memory.h> using n ...

  2. mathType换行等号对齐

    例如: 输入步骤: (1) (2) (3) (4) 事实上,[ctrl+;]表示的是插入了一个对齐标记符.

  3. EF Code First 整不明白 继续完善

    1.Add-Migration RenameDesc  要修改列名先用这个,然后把要修改的列名手动修改一下.  多出这个文件 public partial class RenameDesc : DbM ...

  4. 清除memcached缓存

    telnet localhost 11211 flush_all 最后要一定要关闭dos窗体,不然会导致memcached写值返回ture,但是实际上并没有写入值

  5. 在js文件里调用另一个js文件里的函数

    这个是我今天解决的一个小问题,我在创建界面的时候,根据不同的界面需求对应创建了不同的js文件来搭建界面,搭建完毕之后再将各个生成页面的函数汇总到主界面上,通过visibility属性切换显示,这时候出 ...

  6. CPU核数和load average的关系

    在前面的文章<Linux系统监控——top命令>中我简单提到了,判断load average的数值到底大不大的判断依据,就是数值除以CPU核数,大于5,就说明超负荷运转了.——这里其实不太 ...

  7. Redis 个人理解总结

    一.什么是Redis ? Redis(remote dictionnary server)是一个key-value存储系统.Redis是一个开源的使用ANSI C语言编写.遵守BSD协议.支持网络.可 ...

  8. django信号 signal

    django自带一套信号机制来帮助我们在框架的不同位置之间传递信息.也就是说,当某一事件发生时,信号系统可以允许一个或多个发送者(senders)将通知或信号(signals)发送给一组接受者(rec ...

  9. pip切换国内源(解决pipenv lock特别慢)

    切换方法参考https://blog.csdn.net/chenghuikai/article/details/55258957 实测,确实解决了pipenv这个问题,否则只能--skip-lock. ...

  10. keil MDK注意事项

    1.MDK中的char类型的取值范围是? 在MDK中,默认情况下,char 类型的数据项是无符号的,所以它的取值范围是0-255.它们可以显式地声明为signed char 或 unsigned.因此 ...