- 在线时间
- 479 小时
- 最后登录
- 2026-4-17
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7790 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2923
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1171
- 主题
- 1186
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。
8 N" j. K( d' G6 s5 @
+ I8 q1 e$ P! N- ~2 Q' Q9 C) l |键值对:计算机的非常非常的重要的一种概念。
5 I9 t. H3 {6 Q- U! E( S
' ?6 {3 x* H0 g# N0 D8 D键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
7 |& t# \0 { H/ g6 R6 @' L ^! F$ S! e2 j- X: a; m) X( s
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。 . k0 j6 I! o+ U! y* q r5 p
6 r& J$ H/ k4 F' m+ g7 @- b
在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
7 N* H# x0 X7 {/ m N4 w
9 L8 A5 q2 M3 F# q; }对于字典来说使用in或者[]来获取value都是非常高效的.
6 d2 H1 F: `$ l8 B8 u; e# \: q( u- m$ R; F" a
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
5 B1 b+ O5 k3 N- z
! z2 }/ D" e: [6 x在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
0 Q+ z, G5 `0 G! Y: Z U* S( k1 r% m; v# [) g P3 \5 U' k6 A" b
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
7 N% t$ b5 {- p* T5 G8 M* E, e2 Z) A
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
' r( O& i% H# k9 x7 i7 o+ f; U; U- r/ l" B; s/ a, L/ |
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。7 D5 |0 _/ p' W
: M: g( a4 B# F1 a; n9 H- L遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
+ _" z+ c& R N! U1 X2 o* w
" L k" H, ~9 |7 w+ v4 h$ S% p2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
5 U* h" [1 J3 ]1 S- A! ^* w E& Z- ^+ M! x$ X- E; _
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
, j5 W/ @; V- o/ h
/ t% Q# y$ z9 o. U: x) i6 C字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"9 t8 U" {$ X1 s+ r3 [
————————————————2 r6 ~3 M) |0 Q: t$ v) k
0 G2 S! ^3 X3 V) n2 \. j1 Z" w 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。' h6 i: k' c0 k2 K* h6 [5 h9 F
! }* X# c7 p9 ?4 W9 s7 O" u原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331' }) R. m& r2 Z% l A. {# ~* Z
& f1 S6 A" d( W; x
, D8 ` h' h: G* S) o* O9 b |
zan
|