- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。& B8 u# i& {4 a9 m" @
- _) U2 C, @% j1 H0 J- I% q- j
键值对:计算机的非常非常的重要的一种概念。8 L3 n/ R2 M" ^3 E& W. v
; X6 O0 `5 z/ X& R4 y, z8 F
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
0 W& S0 d2 t6 E" P$ t6 U
& T7 j" B( X7 c- \0 C: h# C在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。 1 z& U, z3 U6 F
% e6 {( o3 h. Q$ F) _# w- Y在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value' O% c4 s. q, i, T( y/ J
6 F( ~) m0 _# P" c/ z对于字典来说使用in或者[]来获取value都是非常高效的.
9 K( p6 q8 }( Q( e2 ^# R' M* V" ]
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
3 q5 \. A9 k+ q) G8 l& N7 M* [5 x, R( ]% \+ A. b; A: a5 S
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
9 @; a* y: X* k; c! q; c0 o1 w5 b
" i7 u; n7 A( j2 F$ Z8 i删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
4 ~' s, f! `8 F; Q8 Z3 G2 h3 g8 a; C+ |& |6 s, n( @$ A0 n# I
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。& r% I6 B; \# @- N5 F1 j& L
- D8 G2 K) I( M
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
- I8 x/ H1 t6 l& ?7 v9 N' \1 d6 b
7 D, U7 ~! Z8 L$ ^5 P1 Q遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致5 p" V9 l9 l" N" K9 q" {. m) n
, ?5 h8 r- B/ `/ _+ i
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)/ {7 m# Z8 E. _+ ~* ^) r# N B
* z+ D: Z1 A1 q. I }, j6 d. ukey类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
& ?7 C) I" r7 b0 H" s: t ~ E5 K# ]( ]- t1 x! h; w1 W
字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
% C3 h$ \% o) G& c5 f& ]————————————————
6 }( H, F8 a. ?9 n
9 D( t3 d9 W% ^' D! H1 d* v% G 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。: R/ ^1 Q% y% r( J6 Z6 Y! L
" N! O! E X$ N; R* N2 x c
原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
- B, Z4 | s' {9 t
# X& Y% g( E% _3 N7 y
) g, P+ x: @' v- K9 e |
zan
|