- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。$ f( H2 I* B. |: a* X" A
" t! i6 G# N, L9 B
键值对:计算机的非常非常的重要的一种概念。8 E* F/ C y$ d% G8 \
. Q% Z; r. ]) \, l7 a% }% _* o键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
5 l' b+ h4 n/ H7 n3 r8 R, }& s) j
) ~- u3 T6 {8 K在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。 5 f4 S* H4 @$ c( X6 W. i
. a ^9 c4 G! B2 [
在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
W% X M3 {6 } R6 Z) N8 o# Z) i9 h6 t. _( r6 R+ o5 q E
对于字典来说使用in或者[]来获取value都是非常高效的.
# k# a# A$ |# y- F# x6 m& q, `5 v. L) I! v6 W) s) M( _: ~
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的." @& ?2 \+ p2 x! U* G6 I% p/ n
( S( M. ]3 H8 t% R. [
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
3 i- U3 X4 F) U
1 L& p P F& Y3 _, L7 Z删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
/ O3 i, ^" v4 @+ q8 H4 W0 t7 v) [7 |0 L
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。 H- t( v; t; Q, _
* H2 E- I1 I, _6 R, i
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。: P$ \. E! w, S0 K: [* u. m( h/ S0 G
0 u$ u% l( V! \. u" @3 F: |
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致2 A# T& k% @. S+ G7 q( F6 V
0 m. V' z* x7 N' b3 E1 s5 K
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
5 H+ e7 H& W6 ~2 A
3 ]2 j* G& q( V1 \7 u5 m; h: }) `key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
! b9 S* f6 [6 p+ V
2 ?* A6 E3 r+ K1 e/ T& Z' _. j: ?, I字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
9 F) W/ V% H: j: @" @& e2 X————————————————
P( {! Q8 w; G5 v5 i A `( J8 T6 m# T, s) H h' u. j
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
6 Y3 v! S8 {# ^( O+ N3 G
, {6 z3 Y3 S) l* x) B原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331# @* Y C3 E$ _/ o
! b, n' {4 Q/ m7 ?7 |
1 J6 j- o9 m- w; x. p
|
zan
|