python学习6-字典

简介: python学习6-字典

一、字典的定义 使用{}定义

1、python内置的数据结构之一,与列表一样,是一个可变序列(可变序列可以进行增删改操作,比如列表、字典 不可变序列不可以进行增删改操作,比如string字符串、整数)

2、以键值对的方式存储数据,字典是一个无序的序列

二、字典的实现原理

字典的实现原理与查字典类似,python中的字典是根据key查找value所在的位置(哈希函数)

三、字典的创建

1、使用花括号{}

scores={'张三':100,'里斯':99,'往往':88}

2、使用内置函数dict()

star=dict(name='张杰',age=40) #{'name': '张杰', 'age': 40}

3、空字典

d={}  #{}

四、字典的常用操作

1、字典元素的获取 []取值和get()取值

  • []如果字典中不存在指定的Key,抛出keyError异常
print(scores['张三'])   #100
#print(scores['张杰'])  #KeyError: '张杰'
  • get()方法取值,如果字典中不存在指定的Key,并不会抛出KeyError异常,而是返回None,可以通过参数设置默认的value,以便指定的key不存在时返回
print(scores.get('张三')) #100
print(scores.get('张杰'))  #None
print(scores.get('张杰',99))  #99

2、key的判断 in/not in 指定的key在字典中是否存在

print('张三' in scores) #True
print('张杰' in scores)  #False

3、字典元素的删除(del clear())

del scores['张三'] #{'里斯': 99, '往往': 88}  del 删除指定的Key-value对
scores.clear()  #{} 请空字典的元素

4、字典元素的新增

scores['陈留']=98  #{'里斯': 99, '往往': 88, '陈留': 98}

5、字典元素的修改

scores['陈留']=100 #{'里斯': 99, '往往': 88, '陈留': 100}

6、获取字典视图的三个方法 keys() values() items()

  • keys() 获取字典中所有key
keys=scores.keys()  #dict_keys(['里斯', '往往', '陈留'])
print(type(keys))  #<class 'dict_keys'>
print(list(keys))  #['里斯', '往往', '陈留']  将所有的key组成的视图转成列表
  • values() 获取字典中所有value
values=scores.values()  #dict_values([99, 88, 100])
print(type(values))   #<class 'dict_values'>
print(list(values))   #[99, 88, 100]
  • items() 获取字典中所有key、value对
items=scores.items()  #dict_items([('里斯', 99), ('往往', 88), ('陈留', 100)])
print(type(items))    #<class 'dict_items'>
print(list(items))    #[('里斯', 99), ('往往', 88), ('陈留', 100)] 转换之后的列表元素是由元组组成的

7、字典元素的遍历

for item in scores:    #item指的是字典元素的键
    print(item,scores[item],scores.get(item))   #后面两种方法都是获取字典元素的值

五、字典的特点

  • 1、字典中的所有元素都是一个Key-value对,key不允许重复,value可以重复
  • 2、字典中的元素是无序的
  • 3、字典中的key必须是不可变对象(比如字符串和整数,不可以是列表,变量)
  • 4、字典也可以根据需要动态的伸缩
  • 5、字典会浪费较大的内存,是一种使用空间换时间的数据结构

六、字典生成式

内置函数zip() 用于将可迭代的对象作为参数,将对象中对应的元素打包成一个元组,然后返回由这些元组组成的列表,会根据少的那个决定

items=['fruits','books','others']
prices=[88,23,43,77]
d={item.upper():price for item,price in zip(items,prices)} #{'FRUITS': 88, 'BOOKS': 23, 'OTHERS': 43}
相关文章
|
15天前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
33 3
|
20天前
|
安全 关系型数据库 测试技术
学习Python Web开发的安全测试需要具备哪些知识?
学习Python Web开发的安全测试需要具备哪些知识?
29 4
|
2月前
|
PyTorch Linux 算法框架/工具
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
这篇文章是关于如何使用Anaconda进行Python环境管理,包括下载、安装、配置环境变量、创建多版本Python环境、安装PyTorch以及使用Jupyter Notebook的详细指南。
299 1
pytorch学习一:Anaconda下载、安装、配置环境变量。anaconda创建多版本python环境。安装 pytorch。
|
2天前
|
存储 程序员 Python
Python学习的自我理解和想法(2)
今日学习Python第二天,重点掌握字符串操作。内容涵盖字符串介绍、切片、长度统计、子串计数、大小写转换及查找位置等。通过B站黑马程序员课程跟随老师实践,非原创代码,旨在巩固基础知识与技能。
|
4天前
|
安全 程序员 Python
Python学习的自我理解和想法(1)
本篇博客记录了作者跟随B站“黑马程序员”课程学习Python的第一天心得,涵盖了`print()`、`input()`、`if...else`语句、三目运算符以及`for`和`while`循环的基础知识。通过实际编写代码,作者逐步理解并掌握了这些基本概念,为后续深入学习打下了良好基础。文中还特别强调了循环语句的重要性及其应用技巧。
|
1天前
|
程序员 Python
Python学习的自我理解和想法(3)
这是学习Python第三天的内容总结,主要围绕字符串操作展开,包括字符串的提取、分割、合并、替换、判断、编码及格式化输出等,通过B站黑马程序员课程跟随老师实践,非原创代码。
|
13天前
|
XML JSON API
如何使用Python将字典转换为XML
本文介绍了如何使用Python中的`xml.etree.ElementTree`库将字典数据结构转换为XML格式。通过定义递归函数处理字典到XML元素的转换,生成符合标准的XML文档,适用于与旧系统交互或需支持复杂文档结构的场景。示例代码展示了将一个简单字典转换为XML的具体实现过程。
10 1
|
22天前
|
存储 网络协议 IDE
从零起步学习Python编程
从零起步学习Python编程
|
2月前
|
机器学习/深度学习 人工智能 架构师
Python学习圣经:从0到1,精通Python使用
尼恩架构团队的大模型《LLM大模型学习圣经》是一个系统化的学习系列,初步规划包括以下内容: 1. **《Python学习圣经:从0到1精通Python,打好AI基础》** 2. **《LLM大模型学习圣经:从0到1吃透Transformer技术底座》**
Python学习圣经:从0到1,精通Python使用
|
2月前
|
机器学习/深度学习 缓存 PyTorch
pytorch学习一(扩展篇):miniconda下载、安装、配置环境变量。miniconda创建多版本python环境。整理常用命令(亲测ok)
这篇文章是关于如何下载、安装和配置Miniconda,以及如何使用Miniconda创建和管理Python环境的详细指南。
446 0
pytorch学习一(扩展篇):miniconda下载、安装、配置环境变量。miniconda创建多版本python环境。整理常用命令(亲测ok)