- 在线时间
- 479 小时
- 最后登录
- 2026-4-17
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7790 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2923
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1171
- 主题
- 1186
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
字典:储存一种键值对的结构。& {0 `& p, s8 f" \
! o/ g' _5 h/ f- p1 ]* M% g7 M
键值对:计算机的非常非常的重要的一种概念。
' P2 k6 Z" u. I
1 |4 p! l3 ?) M, z2 I* @& E1 e$ K键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
- b; r7 T) B4 p- D# [- s2 M1 ]& W: f; @/ S4 q! n
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
8 \& B- R9 |( n, B S9 [& l6 }; v
在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
% S' a% {4 l- @2 {4 |+ r3 K
% \% {: x; X. t' g9 X0 a6 k! y3 T对于字典来说使用in或者[]来获取value都是非常高效的.9 S9 D% I \! C# x- [: }
' c2 V8 }* h1 N. y1 t! J9 N; k- Y) v对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.( l* g; R& d& P4 T+ z+ H
# e! [$ a7 l' H- [4 d% L
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value., C+ n9 |& ^: ~* Q
& A6 s% W# C' {. N! ?, Q删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.; c: [6 ~. d! `2 }
9 E$ G8 N* _( a
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。6 e- ~! V$ M6 M0 y E2 H
2 U* j, u' e, o ~字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。7 ^. @9 v/ y; ~$ ^6 |
3 w) w: s& m) }/ [3 }7 @( C. F
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
7 n& I1 B# x, O/ ?" A
' `, Q6 }) H1 f) S- y7 b$ J2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
( m: L7 Z3 _4 y# ~0 q1 r
" Q( P* `. _! y/ N ]% M' Hkey类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.2 F+ @: _$ B% `
) _0 i- F7 A0 g% k
字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
, ], U6 }4 d( ?& z3 A3 A$ P6 I: H————————————————5 w% Z1 F8 U" ^/ z" b) r) |: V0 A; N
' m/ \" @9 |1 W7 V: B) |1 X 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
1 |) B% `) h7 ^7 U: F& H: [
3 ^" H; Q% Z/ Y I原文链接:https://blog.csdn.net/2301_81874719/article/details/1382123311 g" N! E/ B( p
" e$ Q, V5 L1 m6 |/ A1 G I+ n4 c& r! a) C: k5 B r. d& ~5 s
|
zan
|