- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。
' _( L# s: p7 g2 s; k/ A
* ]" E. p$ H; d# m6 Y键值对:计算机的非常非常的重要的一种概念。
$ ^( v$ R; K8 R9 I( w
; z ?# \7 b1 U) _键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)* G: o! w$ g: w! X; L" E; }
* Y+ ?* C; |! A0 J在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。 ( e% _" P$ |) F7 q
" ?7 L7 z) }* {
在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value! \: |0 ~7 N- D$ ]1 `% U7 T1 m
. t9 u3 { q& \# Z6 D9 k
对于字典来说使用in或者[]来获取value都是非常高效的.
, }! D% U3 ^! M$ Q1 A1 F* B
" x7 B) I8 J7 Y6 C/ Z/ C+ A) v对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
; Z9 _, C& C5 R+ D9 \! ^! }$ g' {% \. i
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
' p2 a1 p; S6 K# q# ^5 N9 z" e- C+ e0 S( w: S" v$ ~/ S
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.1 K5 s+ `6 J8 {, x1 G9 s
B, g' }; j+ ?1 m' d* |字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。0 e+ W. ^' r1 F; I- G
) F2 l/ n) ^: K$ c字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
* V8 k# d9 y# o, I2 h6 C; P4 R4 m4 v0 H2 G
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致* p4 n. a; W2 _5 d# e# Q
7 y0 P8 R. E) o6 G. L6 ?
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
/ h, }# C, x, U$ z3 q* K% L4 r* G* s+ _/ V5 h- P% }2 r
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的." J) x4 }# Q6 a8 p& m
5 V6 }5 R3 d6 j; g* m ?4 x5 N4 Q字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"9 w# J) m1 \3 X" p: A3 S1 R
————————————————- x0 d4 C) v0 B- L6 O& C
+ O4 m8 O% w) a" L* s
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。- }9 f' |2 x7 s/ I
/ d6 O& |# a9 @, x: C3 J6 L
原文链接:https://blog.csdn.net/2301_81874719/article/details/1382123316 J2 f0 I- C* i- ?$ A" h+ |# ]
2 y& z- e+ x6 B
) s( J/ L! Y0 s- [3 q |
zan
|