- 在线时间
- 344 小时
- 最后登录
- 2024-5-29
- 注册时间
- 2023-7-11
- 听众数
- 1
- 收听数
- 0
- 能力
- 0 分
- 体力
- 5891 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2185
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 836
- 主题
- 833
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
|
字典:储存一种键值对的结构。! K+ s' Q9 y5 I3 d( T
: p4 G4 {5 L, k( [# G
键值对:计算机的非常非常的重要的一种概念。+ s: O( U- W2 c2 G- Y7 `
8 C p" E5 t. h3 H. v) ]* X
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
% y6 b: G7 O( W# l; j- Z- H$ O5 @% S, Q, m' h2 y: Z+ d" X
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
6 N# y" s+ j4 E6 q* |; d0 ~2 J! j
$ M4 K0 P D: m- h. q, J在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value0 O: E) j% S7 C, |
' h# Z9 b. T" N; d1 n. C; H: ?
对于字典来说使用in或者[]来获取value都是非常高效的.' R6 z6 {8 x" g, X5 U9 p O5 y
( T0 Q; P& i: a$ W/ R' Z S
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
% V+ e- {& H5 F0 R! p8 Z5 t' L7 R0 s" t' v" L1 o2 U; ~, k
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
1 y* ?( u4 s9 C+ s; `9 q1 o% _* ~8 Y; ?% m, E& s7 g
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的., s" @' \' E2 V% G6 E
. D% i4 x, J0 a; J1 `1 K# ^字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。! H% {4 v% ^0 W# R8 L
* D& `2 y8 u- s: r
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。8 f5 {& ^# g9 a6 i) S. f K8 q6 o
0 E# _( \4 t+ A2 d: N! S% D5 r2 m
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致/ h9 Y! i0 h: n! l+ v6 y& E
% o" c* T+ e* Y1 G! f# ~; F
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
) ^7 j8 v1 ^2 C6 [( i, E
2 S' d# u4 s( W7 L. \$ wkey类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的. y: Y1 I( Q: D3 P2 T
" F3 g6 \+ Q0 u" b* q" w
字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
( i! w8 i" G5 H; W- q————————————————
- q: B6 @) }0 D Z9 q7 |% D* H7 N3 a- Q+ K8 z/ s- i1 }9 d* T
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
5 F! C; {0 O- I. }0 A- g& Y( ~
" G' q: v" \3 a! {1 C( }原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331: R- c% m! b. u/ w
|8 L/ {! P+ \7 {, O" G
* ^7 T7 l: `% |" Q7 k
|
zan
|