- 在线时间
- 479 小时
- 最后登录
- 2026-4-17
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7790 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2923
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1171
- 主题
- 1186
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。- d5 b6 {" |+ O2 [: Z/ E
9 e* o8 s8 Y8 ?0 ~. F" I
键值对:计算机的非常非常的重要的一种概念。
0 a/ Y6 _; G: \7 ~8 H* f
+ m R& R0 T1 Z6 [键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)2 u1 \, a. o4 r- j/ ?% n& ?" ~
/ `: b9 e/ D* `) |' t
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。 * q6 B$ }* A6 y' O
& Y$ V9 X# N+ g* e; q3 [" m在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value' y' {' ]" t @
; n8 D3 a" V+ c. f0 N |$ }对于字典来说使用in或者[]来获取value都是非常高效的.3 g- d! y( h0 E- q4 P
2 b3 L0 k5 _) P+ \* x @( l6 D对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.5 c# [- u& S4 Y& M
. j0 M% d0 ]% O8 C. l
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
. B) o1 Z& x2 J$ ]' K5 W
( H- `8 A9 u, }& o删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
" e9 W" z3 Z6 T8 f6 K
+ X' P7 o9 P. O3 o- U( C字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。7 u" c) B: x3 k& ]
1 \+ T: O6 w1 a- w ] P1 ~字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
' A% M4 y9 d) [4 b! Y9 x& `8 l3 H3 i0 f5 P, H$ S
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
& {7 t% }, x6 g8 g
& }8 W0 O% V7 m" J# R* k4 k& v2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)8 |2 p2 m; s" v3 k: a" N
! F* T9 f# f- ]7 y! i! ^/ x
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
+ @& O w5 A# S+ F2 }5 r7 P5 a! @' E! ]5 E9 r
字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
/ D) h3 `& u* I$ m————————————————0 E5 Z! f) D7 |1 ]! Y* u
+ {6 c$ g' V3 i0 @* @ O1 {, R
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
* t3 R$ p, B' y) U7 V
2 I/ ~& G4 K0 m0 t原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331$ V6 P9 P3 E# K' ^0 k6 O0 V% b' \
8 t" ^$ }% m, o+ u: V; y( ]" [7 z% B A6 c/ O; o
|
zan
|