- 在线时间
- 477 小时
- 最后登录
- 2025-12-17
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7754 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2911
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1169
- 主题
- 1184
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。/ u4 Z/ w1 `$ l8 B
# a7 S6 E( }. b/ Y3 e1 _键值对:计算机的非常非常的重要的一种概念。
8 L5 Q9 d) L) i, p) X n+ H. a: q0 `3 b0 H# J/ d
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
; L, `/ {9 o) {! X @+ t8 T6 A2 ~5 d# J( d* i
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
6 H) H9 L6 \1 ]. P: u- Z/ l" u- k# t0 k0 b9 K2 i! d
在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
; Z( M4 u: i0 M! U2 f# B# |+ _0 b1 X+ O9 v- |/ p0 V4 y
对于字典来说使用in或者[]来获取value都是非常高效的.8 p( {7 {; v# C, ^7 X: k
' r# s) |" T8 M/ }9 s" S. A% y, {对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
* O- T- b- _/ x4 \* D5 E
0 k2 L' J4 N, h7 r) \6 |在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
) l' y* B0 Z. M" j, C O% b; E1 a0 I. N. Z
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.+ P" p! F- ~( U7 E$ D5 C4 Q
# R' [4 u7 t( r8 t
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。) a6 I) |4 p( a- M# @
3 ^# K$ j8 I' @( d字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。% L9 |$ J- L" x5 G8 G: S/ h
* J2 Z+ l+ A4 y$ p; x( i, X遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致7 Q! \, B3 y* Y0 t% t
# u, h8 T L7 _. H3 `# ]* t2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)! L! x/ g( ~! I: n) }2 T6 p9 }, n
. H$ b# Z5 K; S- p7 d* g
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.3 \% v6 H2 O- p3 y. w
) R$ P% C, \" E$ J( g# p" v字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
8 R( v$ v% N, M, k4 L————————————————
$ E- G3 J# K) ]0 ]+ r2 n% S1 P6 L2 X6 X' J. M3 i
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
3 K/ m9 J4 N2 i+ m# d0 X0 Y8 w4 H2 p% H# |2 N
原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331* u9 S" y$ \* I$ I, L% i& P
7 l# N& \( L( X7 g9 d. o
7 A% s+ L4 H: k
|
zan
|