在线时间 480 小时 最后登录 2026-6-1 注册时间 2023-7-11 听众数 4 收听数 0 能力 0 分 体力 7823 点 威望 0 点 阅读权限 255 积分 2934 相册 0 日志 0 记录 0 帖子 1174 主题 1189 精华 0 分享 0 好友 1
该用户从未签到
字典:储存一种键值对的结构。
( S! x* B& m4 ^9 H" z1 n1 }
2 O9 y3 U- v% F9 Q! t' n: X' x 键值对:计算机的非常非常的重要的一种概念。 [, ?) x" r" K1 J+ s
+ i# s$ ^1 {$ m- V+ I& ^6 r
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)( C& l. N" m# m0 V
* n' Y7 C$ w. i5 {# D
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
' b. ^! I! b. G3 _1 C9 X) u % f2 i) X+ H3 d
在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value+ Z, b @$ J/ s* W1 ^
& _3 C% d! ^8 D# d% J5 s
对于字典来说使用in或者[]来获取value都是非常高效的.
! G+ w$ f2 K' C! }5 N3 O' o " x( i" X& k9 A. s2 z+ @
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.& Z% f( ]. r3 T6 n
3 O2 o2 }, Q# ?9 n 在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.: q+ C8 I3 n1 f
+ Q' d# {+ `! `& S* @
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
$ n% R( i3 P+ w' B6 Q: G% E8 |7 [# } 0 c8 ^1 F: f. `: e1 g
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
+ |2 J; O0 [ c+ e h ' H# q+ x# T& M9 t7 ^# N# g
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
7 u1 ?) w9 F! w, L ( y& l6 P- j' {. ~& K+ O
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
8 u6 G4 ~7 s; `" Y % u, k9 Y3 G, ]9 [. N) M# m* Z
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)- m- ~, L# ?, Y r3 c
6 b0 g6 d P' s2 H3 l; \; i key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.# U1 d8 j& A r; Y
. a6 v: T1 Z& e5 K& C 字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
% ?0 h& p N |, Q1 _ ————————————————$ ?, ]. I4 Y3 {: g2 r
, h% a2 d6 ]& C: Z$ d 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。! Y! `$ o5 {8 W; Y3 W
$ C( D5 P$ G" q 原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
8 j0 E/ P) K7 [! j & |) ?- i) ~! a9 c) G2 [0 O( g
; K5 A& q. ?' z2 g' X
zan