Python:字典用法

简介: Python:字典用法

字典


字典的定义

  1. Python内置的数据结构之一,与列表一样是一个可变序列(可以进行增删改操作)
  2. 以‘键值对’的方式存储数据,字典是一个‘无序的序列’
scores={'张三':100,'李四':98,'王五':45}      #三个键值对
# scores--->字典名  '张三'--->键 冒号 100--->值

字典的原理

字典的实现原理:字典的实现原理与查字典类似,查字典是先根据部首或拼音查找汉字对应的页码,Python中的字典是通过hash函数计算key查找value所在的位置。

注意:key一定是不可变序列(不可以执行增删改操作)——字符串str、整数序列range。

可变序列(可以执行增删改操作)——字典、列表


字典的创建

字典创建方法:

  1. 最常用的方式:使用花括号{}
    ex:scores={‘张三’:100,‘李四’:98,‘王五’:45}
  2. 使用内置函数dict()
    ex:dict(name=‘jack’,age=20)
#使用{}创建字典
scores={'张三':100,'李四':98,'王五':45}
print(scores)         # {'张三': 100, '李四': 98, '王五': 45}
print(type(scores))   # <class 'dict'>
#使用dict()创建字典
student=dict(name='Jack',age=20)
print(student)        # {'name': 'Jack', 'age': 20}
#创建空字典
d={}
print(d)              # {}


字典元素的常用操作


字典中元素的获取

  1. []取值——ex:scores[‘张三’]
  2. get()方法取值——ex:scores.get(‘张三’)


[]取值与get()取值区别:

  1. []如果字典中不存在指定的key,抛出keyerror异常
  2. get()方法取值,如果字典中不存在指定的key,并不会抛出keyerror,而是返回None;可以通过参数设置默认的value,以便指定的key不存在时返回
scores={'张三':100,'李四':98,'王五':45}
# 第一种方式:使用[]
print(scores['张三'])   # 100
#print(scores['陈六'])   #报错 KeyError: '陈六'
# 第二种方式:使用get()
print(scores.get('张三'))   # 100
print(scores.get('陈六'))   # None
print(scores.get('麻七',99))   # 99   99是在查找'麻七'所对应的value不存在时,提供的一个默认值

key的判断

  1. in——>指定的key在字典中存在返回True——>‘张三’ in scores
  2. not in——>指定的key在字典中不存在返回True——>‘Marry not in scores’
scores={'张三':100,'李四':98,'王五':45}
print('张三' in scores)       #True
print('张三' not in scores)   #False

字典元素的删除

del scores[‘张三’]——删除指定的 key-value 对

scores.clear()——清空字典的元素

scores={'张三':100,'李四':98,'王五':45}
del scores['张三']
print(scores)     # {'李四': 98, '王五': 45}
scores.clear()    #清空字典的元素
print(scores)     #{}

字典元素的新增

scores[‘jack’]=90

scores={'张三':100,'李四':98,'王五':45}
scores['陈六']=88
print(scores)   #{'李四': 98, '王五': 45, '陈六': 88}
#进行修改
scores['陈六']=100
print(scores)   #{'李四': 98, '王五': 45, '陈六': 100}


获取字典视图的三个方法

  1. keys()—>获取字典中所有key
  2. values()—>获取所有value
  3. items()—>获取所有key,value对
scores={'张三':100,'李四':98,'王五':45}
# 获取所有的key
keys=scores.keys()
print(keys)        # dict_keys(['张三', '李四', '王五'])
print(type(keys))  # <class 'dict_keys'>
print(list(keys))  # 将所有key组成的视图转成列表  ['张三', '李四', '王五']
# 获取所有value
values=scores.values()
print(values)        # dict_values([100, 98, 45])
print(type(values))  # <class 'dict_values'>
print(list(values))  # [100, 98, 45]
#获取所有key-value对
items=scores.items()
print(items)        # dict_items([('张三', 100), ('李四', 98), ('王五', 45)])
print(type(items))  # <class 'dict_items'>
print(list(items))  # 转换之后的列表元素是由元组()组成的  [('张三', 100), ('李四', 98), ('王五', 45)]

字典元素的遍历

for item in scores :

print (item)

scores={'张三':100,'李四':98,'王五':45}
for item in scores:
    print(item,scores[item],scores.get(item))
输出:
张三 100 100
李四 98 98
王五 45 45

字典的特点

  1. 字典中的所有元素都是一个 key-value 对,key不允许重复(一旦重复,前面的value会被覆盖),value可以重复
  2. 字典中的所有元素是无序
  3. 字典中的 key 必须是不可变对象—— str 整数
  4. 字典也可以根据需要动态的伸缩
  5. 字典会浪费较大的内存,是一种使用空间换时间的数据结构
# key 不允许重复
d={'name':'张三' , 'name':'李四'}  
print(d)   #{'name': '李四'}
# value可以重复
d={'name':'张三','nikename':'张三'}  
print(d)   #{'name': '张三', 'nikename': '张三'}
#如果字典的key是可变对象list,则会报错
lst=[10,100,60]
d={lst:100}
print(d)   # TypeError: unhashable type: 'list'

字典生成式

内置函数zip()

——用于将’可迭代对象’作为参数,将对象中对应的元素打包成一个元组,然后返回由这些元组组成的列表


{表示字典key的表达式 : 表示字典value的表达式 for自定义表示key的变量, 自定义表示value的变量 in zip( , )}

zip()——可迭代对象

items=['Fruits','Books','Others']
prices=['96','78','85']
d={item.upper():price for item, price in zip(items,prices)}
print(d)   #{'FRUITS': '96', 'BOOKS': '78', 'OTHERS': '85'}
#upper()---将items中所有字母变大写

总结

1、字典的创建

a. 使用{} 花括号
b. 内置函数dict()
c. 字典生成式

2、常用操作

a. 获取value

1)字典名[key]

2)字典名.get(key)

b. 删除key-value对

1)del 字典名[key]
c. 修改\新增
1)字典名[key]=value
d. in \ not in 判断

3、获取视图的三个方法

a. keys()—>获取字典中所有key

b. values()—>获取所有value

c. items()—>获取所有key,value对

4、字典生成式
{表示字典key的表达式 : 表示字典value的表达式 for自定义表示key的变量, 自定义表示value的变量 in zip( , )}

相关文章
|
26天前
|
Go 调度 Python
Golang协程和Python协程用法上的那些“不一样”
本文对比了 Python 和 Go 语言中协程的区别,重点分析了调度机制和执行方式的不同。Go 的协程(goroutine)由运行时自动调度,启动后立即执行;而 Python 协程需通过 await 显式调度,依赖事件循环。文中通过代码示例展示了两种协程的实际运行效果。
|
4月前
|
人工智能 数据库连接 API
掌握Python的高级用法:技巧、技术和实用性示例
本文分享了Python的高级用法,包括生成器、装饰器、上下文管理器、元类和并发编程等。生成器通过`yield`实现懒加载序列;装饰器用于增强函数功能,如添加日志或性能分析;上下文管理器借助`with`语句管理资源;元类动态定制类行为;并发编程利用`threading`和`asyncio`库提升任务执行效率。掌握这些高级概念可优化代码质量,解决复杂问题,提高程序性能与可维护性。
101 6
|
5月前
|
Python
Python教程:os 与 sys 模块详细用法
os 模块用于与操作系统交互,主要涉及夹操作、路径操作和其他操作。例如,`os.rename()` 重命名文件,`os.mkdir()` 创建文件夹,`os.path.abspath()` 获取文件绝对路径等。sys 模块则用于与 Python 解释器交互,常用功能如 `sys.path` 查看模块搜索路径,`sys.platform` 检测操作系统等。这些模块提供了丰富的工具,便于开发中处理系统和文件相关任务。
218 14
|
6月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
|
6月前
|
存储 人工智能 索引
Python数据结构:列表、元组、字典、集合
Python 中的列表、元组、字典和集合是常用数据结构。列表(List)是有序可变集合,支持增删改查操作;元组(Tuple)与列表类似但不可变,适合存储固定数据;字典(Dictionary)以键值对形式存储,无序可变,便于快速查找和修改;集合(Set)为无序不重复集合,支持高效集合运算如并集、交集等。根据需求选择合适的数据结构,可提升代码效率与可读性。
|
6月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
本文来自YashanDB官网,介绍如何处理Oracle客户端sql*plus中使用@@调用同级目录SQL脚本的场景。崖山数据库23.2.x.100已支持@@用法,但旧版本可通过Python脚本批量重写SQL文件,将@@替换为绝对路径。文章通过Oracle示例展示了具体用法,并提供Python脚本实现自动化处理,最后调整批处理脚本以适配YashanDB运行环境。
|
8月前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
264 2
|
10月前
|
XML JSON API
如何使用Python将字典转换为XML
本文介绍了如何使用Python中的`xml.etree.ElementTree`库将字典数据结构转换为XML格式。通过定义递归函数处理字典到XML元素的转换,生成符合标准的XML文档,适用于与旧系统交互或需支持复杂文档结构的场景。示例代码展示了将一个简单字典转换为XML的具体实现过程。
155 1
|
10月前
|
Python
Python三引号用法与变量详解
本文详细介绍了Python中三引号(`&quot;&quot;&quot;` 或 `&#39;&#39;&#39;`)的用法,包括其基本功能、如何在多行字符串中使用变量(如f-string、str.format()和%操作符),以及实际应用示例,帮助读者更好地理解和运用这一强大工具。
876 2
|
11月前
|
缓存 测试技术 开发者
深入理解Python装饰器:用法与实现
【10月更文挑战第7天】深入理解Python装饰器:用法与实现
86 1

热门文章

最新文章

推荐镜像

更多