- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。
" G0 v( ]* V b* H6 F
1 g5 r% I- x1 Q4 O( x4 W9 X% b键值对:计算机的非常非常的重要的一种概念。
; z0 O" Y9 ]6 Z# ^* f5 t. M9 W
. s- b2 F( J; P! F. }. m5 q' f键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
8 r$ A, E- ?9 C# F# D$ u) w5 f
5 ~& b2 n& r+ K在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
- ^! V! E+ D6 }7 O& G
4 ~) U# J W* F' Y" Y: m+ u: u在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value9 ] T+ A3 t# [ S- \
5 a' }* i: G! s' z% M9 L
对于字典来说使用in或者[]来获取value都是非常高效的.
2 Y" w, q# z5 V3 r6 A: j; b( [# n8 R l" z( D
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.7 ~3 s" }+ T* J
; o2 E* m$ h( F+ f
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.. \& s% {9 r% ?) E
: v8 U! y) v; V/ Q1 j. ]4 N
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
. Q. w ]* N3 [, d2 e* c$ Y) b- c5 K$ g
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
0 d/ e0 B# u$ Y B+ Q
7 w; h2 M. j! {2 e# Y1 n字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
( C8 z7 i5 W; @; L0 c
7 J" T5 S2 l; p$ s; Z' _9 Y3 p( H+ q遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
1 X) t, {/ N) [+ J1 K5 B [4 b8 O/ `6 `& i7 a
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
2 G/ O- F4 t8 a* v) p8 ?; w5 w+ ?: B- G* V8 y8 I
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的." a7 N5 C& C+ F$ k
% y- ~* H) q; ?- e3 |, H字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"- g- Z6 z0 s3 ^- n/ J6 B5 j
————————————————- }7 U: N6 q8 W7 i% A, D
. q/ ?" C2 `) K- {% v4 }
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。0 G* i: x0 q: Y
9 j& L7 D$ l6 Y4 N2 ^原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
1 B( f7 N6 `% s" Y5 |+ o @/ h
# C. X! a/ F4 w: F; U- M
* X3 q" c. C" J+ H0 i1 c; m' V0 } |
zan
|