- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。
# p$ v' A0 E; S
7 K. P; m+ Q% I/ E键值对:计算机的非常非常的重要的一种概念。
+ D" T% |/ a* b9 Y( |% M! _, ] V$ y* p
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)+ d) i+ B4 Q; X, }- W/ c* v& S
$ a/ [6 Q5 H1 Y0 C2 j在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
/ z2 m k, A! V: D( e' W% y
" ?) n h% g+ u4 L5 x5 f在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value4 {/ R, B" S1 b ]& J6 A
; \! }3 G! C+ U( P
对于字典来说使用in或者[]来获取value都是非常高效的.4 r" X, _ M2 \7 Q' f. c: h& F
( A! A& z6 A# @9 M6 g( f: Z& y% J对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的." {+ R5 S) f6 L5 x5 l/ a
; r+ g5 t6 |/ {; @$ F# I0 Q* o3 G在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
7 F9 K i. V; O0 b
0 a6 v+ p7 [- q删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.8 t# Y$ f4 e; i U
, Z6 k0 D" Q. h5 \8 P4 m字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
. @/ R5 u4 D6 d- e) ^) F3 K. N/ [! D+ Z
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
. f% O* T1 F! r& A* |3 D% T7 g3 r% h7 u: L# R* |! t. G4 Y
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
' J& I) n- }- Z6 a' c' D+ j& P; O" g8 X. S$ A7 J7 J( |3 d9 _
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)- ^. ^7 {0 c$ D" \
1 S. d* Y7 ?' Q( o2 c# | ]key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
1 u* m7 R& m; N* g6 C |$ w; s( t) ^
字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
5 o r# d9 }( O0 A& \0 ]————————————————; Y+ F) d/ ]! a; ]6 B3 f( h4 Q: y
" D, h3 A' N: D' ?1 Y 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。* ~, ?. @9 _6 g
% S- g. m9 f7 z" x& ^/ u原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
7 ~. x" c% X5 w, N) A
) N& R1 J+ B& h8 ]' n* X
1 ^/ p5 R2 @- Z, m6 k% `3 @4 J |
zan
|