数学建模社区-数学中国
标题:
python字典方法大全
[打印本页]
作者:
2744557306
时间:
2024-4-26 16:23
标题:
python字典方法大全
字典:储存一种键值对的结构。
8 L$ ]* o" }) S* ^* Z1 Y
6 q2 h3 l1 @3 s |- E3 \
键值对:计算机的非常非常的重要的一种概念。
- g2 E& p7 h$ G2 ^0 {6 z# l+ g
/ m/ D. e9 @ E4 l
键(key)值(value) 根据键key可以快速找到value(本质其实是一种映射的关系)
& E4 ]* [! L# a& H$ o$ P
. o' z5 B9 O3 p; P4 _
在Python的字典中可以同时包含很多键值对,但要求这些键不能重复。键值对形式{key:value , key:value…}字典中的key和value的类型不一定都一样,字典对于key是什么类型有约束,但对于value是什么类型无约束.一般没写一行,因为不直观,一般写成这样多行更直观,最后一个键值对的逗号可有可无。
4 @6 l; ]2 s) O e$ ~
- V' w% [- g/ c2 \, a1 N3 z
在字典中查找有两种方式:1.可以用in来判断某个key是否在字典中存在 2.使用这个[]来根据key来获取value
8 {+ `1 T) P# V
, p# F! t3 f) Y# `
对于字典来说使用in或者[]来获取value都是非常高效的.
. Z7 G- x1 g, i
- l" g1 F( f( ^7 G q. v2 J* `
对于列表来说用in比较低效因为要全部遍历,而使用[]是比较高效的.
5 U) Z0 O8 R9 i w
# V" B/ P% P1 J& _( b" _
在字典中新增键值对的方式:在字典中新增元素用[]来进行,例:对象[key]=value. 如果key不存在往里写,相当于新增键值对,如果key存在往里写,相当于根据key修改value.
: h4 L M' U0 E" d, ^( O( h5 n
$ {* b5 ]7 A* n; p) P) F8 E, Z7 z
删除:使用pop方法,根据key来删除键值对,对字典的各种操作都是围绕key来进行的.
0 X9 f0 w! _. J! R) M
$ j- z6 N9 D) _
字典被设计出的初衷不是为了遍历,而是为了增删查改,时间复杂度O(1),增删查改都是固定时间,不会因为元素多了而操作就慢了。
& G9 m- k2 k& _7 y1 e
; [8 h* H( h, o: D, d5 a, T
字典是哈希表进行增删查改操作的效率非常高,而字典的遍历则效率差一些。
# F3 t* N7 ]2 g6 b9 R. s
& u( H, O8 J5 a! A8 q
遍历:1.用for循环,来遍历字典.在Python中能够保证遍历的顺序和插入的顺序保持一致
5 C& E( ^# a/ h
0 R# j% F0 |5 F8 U- i
2.使用keys()、values()、items()(分别表示所有的key,所有的value,所有的键值对)
( Q0 q( u! P- q0 r0 l
) ^* k: M/ o/ H1 A9 K! ?; J
key类型的约束:不是所有类型都可以作为字典的key,因为字典本质为哈希表而表中key要求可哈希的,也就是可以计算出一个哈希值,刚好Python有一个内联函数哈希hash可以计算函数哈希值,注意字典dict和列表list是不可哈希的.
$ f; |; M1 v6 D: \% c7 J
; U3 }0 E* k; w+ k) m9 } Q
字典和列表、元组是Python当中非常常见的内置类型,相比于int string float,它们内部可以包含很多元素,所以被称之为"容器和集合类"
, }; u6 C4 x" K; i( E1 {
————————————————
- D7 N. U* l3 G" D
4 }4 ^8 M; Q- z1 Q5 g m, _
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
w7 c. p2 u# V, F+ n) W
& H2 u: I! |6 D9 K; U# O; O
原文链接:https://blog.csdn.net/2301_81874719/article/details/138212331
0 j3 k i8 w% a2 a
9 X* t0 `& g: I* o) t$ N
- v# Q/ g& L* U5 A' A: M3 M9 x
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5