- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。6 X: z1 z, V* r. j+ E
8 R4 I+ s0 @" g k1 d- z+ D键值对:计算机的非常非常的重要的一种概念。
& _' u+ N3 z, [ t x& K& z2 e6 N$ W/ g9 U7 [
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
8 S! j J k" M! }, W. @5 m0 f0 R0 a8 _
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
. Q% x2 ]( T8 x# v' ~$ g1 y# ?, f
9 p, j" U7 j7 ?) x, ~8 F& r& S在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
0 Z! P N% H# b. x ?4 O* F& x) x. H% `+ {6 X5 N t P
对于字典来说使用in或者[]来获取value都是非常高效的.
9 a! l) I6 k$ q6 B7 `8 r2 `/ o3 e0 U: }% S
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
4 F+ I* H- @; g5 W& I8 J9 r- x8 Z. ^
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
4 ^6 x# M6 I2 n0 u1 d2 _" y
, J M9 \% c4 e& A2 g0 X删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
7 a( V! _" H$ @+ L' o: x, l; ^; D* V8 J, q+ C3 Z# w" N
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。5 m f4 F. w# Z. H# i0 K: ?5 c
* \" {$ j& j& E( ~7 b0 k ^字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
1 _" C. r8 C' P! N
: X- u- [/ s* N( Y) J; I( y遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致1 q W6 Z8 M M" V8 h- e
/ w1 @4 D* @' b, ]2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对), u: f& [; R9 e7 n
& B4 F( r3 c! Okey类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
+ M& i$ n4 ]" k( D* |2 |" e( }
* v) x: S: ?2 z2 r, i1 x) a7 |: n字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"- F0 T! Y q4 A& z+ \# \
————————————————
0 V0 _' \! ?/ {6 Q" l" u; q
: R# J: ~ Z* Q& K. W; W" l 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。; b" W! `1 g$ w0 x% @0 ^/ e
' [# P9 r5 L: ^" Y
原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
# s0 l; @) d4 R1 S
) u, a/ _$ ]' ^3 ^; |5 X
( I `0 d. H$ e+ S* e |
zan
|