- 在线时间
- 479 小时
- 最后登录
- 2026-4-17
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7790 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2923
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1171
- 主题
- 1186
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。
% [* d- I8 F# m+ C6 W7 ^8 `2 g
r' C3 d- {: P r. K3 ]键值对:计算机的非常非常的重要的一种概念。
) x; n2 I- w' o- B
6 a X' I. m) U' s8 T键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)9 d* i4 T+ q' @: B
8 N+ ]2 x* [* w: y2 Q
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
# z4 J6 P4 K; q1 o
. v+ t: n, c$ c& @在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value% U& c7 A8 L3 c7 H
9 b& D+ ]7 e0 X Y
对于字典来说使用in或者[]来获取value都是非常高效的.# h, E/ C5 I |( C3 @/ C
' K0 E9 G% j! @% W ]对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
* K7 w C& k4 \" O* H& Y& n4 W
' [4 b* i$ h0 i; ^( i8 g在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
% A4 e4 b$ D( I3 |
/ W' i$ t: i2 U5 e1 l; @; I. m删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.8 \5 |- ^) X: w1 W* K3 W9 W+ t
0 [2 F5 I* l" L: m& @) ]字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
5 Z- x9 u- E" D W5 h% P' k% G( V) \# T2 |/ G& X- o$ [, f
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
9 w' h( O, K' e! x% J, [% N; r! L3 l
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
+ r2 U! @, h: r# y7 f7 L) u& r- f$ ^$ r. ? `; x5 N
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)( z! |, e, f& s9 p; n9 ~8 ?. |
+ ?9 G1 D( K8 L2 \/ p& m+ O
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
0 ~! b& a, f/ s4 j/ W* k
* g0 ~* M1 t7 i2 L; a$ J k+ [) m字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"; V7 J3 l4 {5 E: @, T L
————————————————
/ b* H. e @ o" _2 o. a* A, h# q2 r2 H9 P: f" u) P- D" R
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
4 E+ m4 b+ e: E( X% F; X, `& u$ h, M0 }! J
原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
1 V) O+ z, T3 l4 s2 F( m. S. J7 I b9 X! A' m
c: _. n- h6 f y- ?
|
zan
|