- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。
s2 n) s) k+ U8 i" O) A2 D
9 R0 V7 X8 f( Y$ e( V! r4 }键值对:计算机的非常非常的重要的一种概念。
* c6 {3 V9 H8 Z* X
1 s& _( M6 a; d9 k, N键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
" D* O/ e7 r/ q) H# A9 s
8 O) S# z$ q3 K7 E3 k- v在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
4 k; m% ?8 b% z' m$ c
) O/ j) @& p5 y% B9 F R3 |+ I在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
$ D0 s, i7 V: k) W4 P1 { o- `! [8 P+ |4 n
对于字典来说使用in或者[]来获取value都是非常高效的.
- i3 Y8 j" ^! W$ W2 e5 f. `
/ s4 m, |) U# E8 ^3 ^; \/ x对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
- C$ h8 e9 k l# P& O' W: y, C& ]+ E" S+ ~/ b8 P# l
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
* V- v$ W" q- k
4 ]9 q$ F4 x; s0 G5 N( ^1 U删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的., S, f# Z# W* y% [8 N4 ~+ [) }
! O" m h0 p& k4 U1 l2 b3 j' _
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
9 Z+ t/ b8 {5 v
1 O9 q9 [3 b/ k- k. Z' v5 l字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。, V" j, N0 F- k% L5 H
' |- O) z( O6 F7 b; s; F遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致* g$ B7 ~! g! K; N% R4 R+ F- U0 B: z
5 t: N) R2 [; ?2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)( f2 A2 d5 O5 [0 I3 f. P/ B
% `( n! W; T5 R! c+ I
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.0 p4 N9 n# U' \
3 Z7 R* H' i# j, w9 |" }3 @字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
, {/ d( l$ V. f8 o& L& j; H& _————————————————" g; a, M5 j, N5 l$ I! N' J6 z7 F; u
( \% l% p% ]: C) O- H
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。6 n+ h& Z# F. P# R7 g! U
% R3 j4 [ H8 Z9 }7 a原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
% _& x5 D: J2 {7 o; r( {3 F0 u# d& v+ b0 A7 V9 y+ j5 U1 i6 d3 h8 V/ T. M
2 A. a% t4 b3 b/ W+ m- ^( C
|
zan
|