- 在线时间
- 479 小时
- 最后登录
- 2026-4-17
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7790 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2923
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1171
- 主题
- 1186
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。9 p" t, K2 ^# B) z3 W! n1 P
5 ]' G- H% l& Z键值对:计算机的非常非常的重要的一种概念。
; q) N( _1 _0 G4 C K3 e/ B" t, l8 i( f/ R1 p
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)8 D9 _( j+ R* A8 D
( r1 b& v/ e) s3 _8 a2 q& w) }
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。 % Z$ n4 b/ y9 ]5 [
$ |( Q" \7 C2 o4 r& }在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
2 m7 T9 t" B% I& M. p8 Q) H% {" I4 K+ F& W7 H+ @% j
对于字典来说使用in或者[]来获取value都是非常高效的.
1 T) ~5 U' _! l8 k
- x/ r; ^7 ^7 N" D对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
5 }) e/ u& ^7 Y) |3 C9 l1 m. Y6 q N4 N, A: F. d& p
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.5 X% j* c7 m4 n: R. O. U2 m1 I
2 J; c/ {' I* j# G
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
3 \2 ?# }( L: L% D) `
% i4 m( |& [* N4 N字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。# O! R8 F1 N# B8 s
7 N4 M8 b! N0 T2 H% C' P7 m
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
# t3 `" Q9 P- Z W, T5 q1 l; f, P. F/ Y/ q" D0 \8 u1 A' `
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
/ _" W# {# u+ ?" B! C+ @. n2 ]3 i% T: {. o* P, E3 ?6 m
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对). w9 a/ u' ~! G
2 l2 W; d* a! W: \key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
1 R+ \' K9 E8 s8 E* j0 G! d9 ^
. R8 d- Y, Y7 E* u字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
3 G! Z, M, b" u+ m% N————————————————
2 f1 d& s, n" I, ?# b$ U2 f
+ V, Z' B, C( i% { 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
8 w9 L1 r1 V+ }& w+ ]
8 x: c$ ~- ^/ C* y原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
0 h) S* d! k& @/ p) q5 z% t6 `6 a$ K+ t
. `( g3 z; X' Y( s+ n( ]: Q
|
zan
|