在线时间 462 小时 最后登录 2025-4-26 注册时间 2023-7-11 听众数 4 收听数 0 能力 0 分 体力 7220 点 威望 0 点 阅读权限 255 积分 2744 相册 0 日志 0 记录 0 帖子 1156 主题 1171 精华 0 分享 0 好友 1
该用户从未签到
字典:储存一种键值对的结构。$ ]1 w" Q8 u8 {* c$ ^; _7 _
3 Y! U- h& L' o 键值对:计算机的非常非常的重要的一种概念。
! T% p ~2 ]9 I. Y9 g / x! y& S. A2 O' H8 Q
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)) [ P2 q1 e# y. O, M( r7 O- j7 U/ D
0 P! k, ]- E3 F* v6 q 在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。 6 ^( s" P5 C6 M
4 i" n6 A4 B/ [ \( W( n 在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
1 S: V! l+ P: ]0 a+ j- x 7 `% o* y: Q& V. Y2 v$ b- }
对于字典来说使用in或者[]来获取value都是非常高效的.4 S* h. L! f' H: s
' _7 A( h+ I/ i0 V 对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
& z! W- c" {2 {' m: |: i& H
+ q: E& m7 K, w; T' M 在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.% J3 l; f9 H O6 ^2 Q. @" }9 r
: _4 M' r3 S2 N1 j( [/ X5 i0 m& q 删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
6 y6 p, }" t" J* E p P: n3 E
1 o0 W: t$ Z3 Z" E) h6 }, V0 s3 f 字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
2 j: U3 Q) P7 J# s/ ~0 o9 r
: ?2 j& v2 y6 d h% o: Z 字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。0 f' i( E2 D& o( Y
0 O7 X# R8 I3 A0 q A 遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致) P& u; b! }9 _! @
9 `" u& } p3 ^ 2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
+ X" d1 t1 o; e! S
- |' W4 w/ L, ?% @ key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的./ S" `/ C0 w9 W: N; @3 m5 z
r8 K7 F3 u; e$ e- W2 n) h
字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"6 e# W( a' c5 B+ O
————————————————
- Z. l6 s# ]7 s2 Q [, o " @) q8 C$ e, w& S- v7 S
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
& [% e% z3 f) o) f U6 \ + [6 d4 q) i) H4 y& L& o& ^, ]
原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
, |2 w& t) p7 t! W9 M: h# e
) F. ~! B: o! B* b q5 b( I2 v+ `
1 Z9 L- J1 g- }- k7 n0 D
zan