Python(18)-字典dictionary、集合

Python高级数据类型-字典

  • 1.字典的定义
  • 2.字典的基本操作:查询,增加,修改,获取
  • 3.字典的统计、合并、清空
  • 4.字典的循环遍历
  • 5.返回最大“值”对应的“键”
  • 6.应用场景
    • pop(key)
  • 7.集合

字典是除了列表之外最灵活的数据类型,用来描述一个物体的关键信息,比如描述一个人的特征,身高,体重,年龄,

1.字典的定义

字典: 用于存储无序的数据类型,不关心数据保存的顺序,用键来访问保存的数据
列表: 用于存储 有序 的数据类型,用索引访问—有序

定义方式1–用{}+Key:value定义,键值对之间用逗号分隔。

#一个键值对占据一行,看起来比较清晰
xiaoming={"name": " xiaoming","age": 18,"gender": True,"height": 1.75,"weight": 65}
print(xiaoming)

定义方式1–dict()+元组

items = [('height', 180), ("weigh", 124)]
D = dict(items)
D2 = {'height': 180,'weigh': 124}
# 字典的遍历

键用来获取数据,最常用的键的类型是字符串,值用来保存数据,键应该是唯一的。

输出: 输出的顺序和定义的顺序一般不同,因为字典是一个无顺序的数据类型

{‘gender’: True, ‘age’: 18, ‘name’: ’ xiaoming’, ‘weight’: 65, ‘height’: 1.75}

2.字典的基本操作:查询,增加,修改,获取

xiaoming_dict={“name”:“xiaoming”}

1.查询:中括号+Key,指定的Key不存在时,程序会报错(取值)

print (xiaoming_dict[“name”])

2.增加键值对,如果key存在会修改该值,如果不存在会新增一个键值对

xiaoming_dict[“age”]=18

3.修改变量值,格式增肌键值对相同

xiaoming_dict[“name”]=“xiaoxiaoming”

4.删除指定键值对,key不对程序报错

xiaoming_dict.pop(“name”)
print(xiaoming_dict)

删除后输出:{‘age’: 18}

5 获取 键 对应的值,如果键不存在,则返回None,比第一种方法好用 (default用于指定键不存在时返回类型)

dict.get(key, default=None)

6.返回所有值

z={“a”:1, “b”:2}
print(z.values())
#输出 [1, 2]

3.字典的统计、合并、清空

xiaoming_dict={“name”:“xiaoming”,“age”: 18}

1.统计键值对的数量,(输出2)

print(len(xiaoming_dict))

2.合并字典

temp_dict={“height”: 1.75, “age”: 20}
xiaoming_dict.update(temp_dict)

输出:{‘age’: 20, ‘name’: ‘xiaoming’, ‘height’: 1.75}

被合并的字典中已经包含存在的键值对,原有的会被覆盖,如此例子中的name.

3.清空字典

xiaoming_dict.clear()
print(xiaoming_dict)

输出:{}

4.字典的循环遍历

xiaoming={"name": " xiaoming","qq": "123456","phone": "10086"}
#变量K是每一次循环中获取到的键值对的Key
for k in xiaoming:print ("%s-%s"%(k,xiaoming[k]))

输出:

qq-123456
phone-10086
name- xiaoming

5.返回最大“值”对应的“键”

counts={1: 1, 2: 1, 3: 1, 4: 2, 5: 4}
max(counts.keys(), key=counts.get)

key=counts.get 中的key 是max的参数,
counts.keys()获取的是字典的所有值,获取最大值之后,用get 返回最大的的键?

6.应用场景

字典一般与列表一起使用,定义多个字典,放在同一个列表变量中,循环遍历列表,在循环体中对每一个字典进行相同的处理。

card_list=[{"name": "zhangsan","qq": "12345","phone": "110"},{"name": "lisi","qq": "123457","phone": "10086"}
]
for card_info in card_list:print(card_info)

输出

{'qq': '12345', 'phone': '110', 'name': 'zhangsan'}
{'qq': '123457', 'phone': '10086', 'name': 'lisi'}

pop(key)

弹出对应的值

dit={1:"r",2:"b"}
print(dit.pop(1))
print (dit)

leetcode128:重复元素,hash表实现线性时间查询

class Solution(object):def singleNumber(self, nums):""":type nums: List[int]:rtype: int"""li={}for val in nums:try:li.pop(val)except:li[val]=1return li.popitem()[0]  # 弹出元素,键为需要的答案

7.集合

集合-不可变的无序集合,元素唯一,用大括号定义,支持集合的交和并操作

set1 = {1, 2, 3}
set2 = set([2, 3, 4])
set3 = {1,1,2,3,5}  # 实际set3 = {1,1,2,3,5}
print(set1 - set2)  # 集合求差,包含在x 但是不包含在y中的元素:{1}
print(set1 | set2)  # 集合求并:{1, 2, 3, 4}
print(set1 & set2)  # 集合求交:{2, 3}
print(set1 ^ set2)  # 集合求异或, 只被一个集合包含的元素 {1, 4}
print(set1 > set2)  # 包含关系,set1 真包含于set2,返回True :False

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/445276.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redis——Redis中的LRU算法改进

redis通常使用缓存,是使用一种固定最大内存的使用。当数据达到可使用的最大固定内存时,我们需要通过移除老数据来获取空间。redis作为缓存是否有效的重要标志是如何寻找一种好的策略:删除即将需要使用的数据是一种糟糕的策略,而删…

redis——HyperLogLog

HyperLogLog 是一种概率数据结构,用来估算数据的基数。数据集可以是网站访客的 IP 地址,E-mail 邮箱或者用户 ID。 基数就是指一个集合中不同值的数目,比如 a, b, c, d 的基数就是 4,a, b, c, d, a 的基数还是 4。虽然 a 出现两次…

机器学习知识总结系列-机器学习中的优化算法总结(1-4)

文章目录1.梯度下降1.1批量梯度下降(BGD)1.2随机梯度下降(SGD)1.3 小批量随机梯度下降(MSGD)1.4 比较:1.5 动量算法(momentum)1.6 Nestrov Momentum2. 自适应方法2.1 自适应学习率算法&#xff…

Python(19)-字符串、Unicode字符串

高级数据类型--字符串、Unicode字符串1.字符串的定义2.字符串的长度、计数、Index3.字符串常用方法3.1判断类型3.2查找和替换3.3文本对齐3.4去除空白字符.strip()4.字符串的拆分和拼接5.字符串的切片6.跨行字符串7.包含转义字符r8.字符串的分割与连接9.Unicode字符串字符串-不变…

机器学习中的距离和损失函数

文章目录13.1 距离度量13.2 损失函数13.1 距离度量 距离函数种类:欧式距离、曼哈顿距离、明式距离(闵可夫斯基距离)、马氏距离、切比雪夫距离、标准化欧式距离、汉明距离、夹角余弦等常用距离函数:欧式距离、马氏距离、曼哈顿距离…

Python(20)-高级数据类型的公共方法

高级数据类型的公共方法1内置函数2高级数据类型切片3运算符,*,in4完整的for循环公共方法是列表,元组,字典,字符串都能使用的方法1内置函数 内置函数:不需要import导入模块,就可以直接使用的函数…

redis——为什么选择了跳表而不是红黑树?

跳表是个啥东西请看这个文章。 我们知道,节点插入时随机出一个层数,仅仅依靠一个简单的随机数操作而构建出来的多层链表结构,能保证它有一个良好的查找性能吗?为了回答这个疑问,我们需要分析skiplist的统计性能。 在…

机器学习公式推导

文章目录线性回归逻辑回归线性判别分析PCAk-means决策树svm随机深林GBDTxgboost强化学习MapReduce线性回归 逻辑回归 对于分类问题:输出0/1,超过[0,1]没有意义,使用sigmoid函数 **代价函数:**使用L2平方差,由于模型函…

Python综合应用(1)--名片管理系统开发

第一个综合应用-名片管理系统1框架搭建2完善功能综合应用,名片管理系统 欢迎界面,不同选项,1.新建名片,2.显示全部,3 查询名片(查到之后可以修改名片信息),0 退出系统 程序开发流程…

springboot1——spring相关入门

spring 随着我们开发,发现了一个问题: A---->B---->C---->D 在A中创建B的对象调用B的资源 在B中创建C的对象调用C的资源 在C中创建D的对象调用…

大数据学习(06)-- 云数据库

文章目录目录1.什么是云数据库?1.1 云计算和云数据库的关系1.2 云数据库的概念1.3 云数据库的特性1.4 云数据库应用场景1.5 云数据库和其他数据的关系2.云数据库产品有哪些?2.1 云数据库厂商概述2.2 亚马逊云数据库产品2.3 Google云数据库产品2.4 微软云…

Python(21)--变量进阶

变量的进阶使用1变量引用2可变、不可变数据类型3局部变量和全局变量4.Tips本系列博文来自学习《Python基础视频教程》笔记整理,视屏教程连接地址:http://yun.itheima.com/course/273.html在博文:https://blog.csdn.net/sinat_40624829/articl…

HTTP 响应代码全集

HTTP 响应状态代码指示特定 http 请求是否已成功完成。响应分为五类:信息响应(100–199),成功响应(200–299),重定向(300–399),客户端错误(400–499)和服务器错误 (500–599)。状态代码由 section 10 of RFC 2616定义 信息响应 …

机器学习知识总结系列-机器学习中的数学-矩阵(1-3-2)

矩阵 SVD 矩阵的乘法状态转移矩阵状态转移矩阵特征值和特征向量 对称阵 正交阵 正定阵数据白化矩阵求导 向量对向量求导 标量对向量求导 标量对矩阵求导一.矩阵1.1 SVD奇异值分解(Singular Value Decomposition),假设A是一个mn阶矩阵&#xf…

阿里Java编程规约(注释)提炼

【强制】类、类属性、类方法的注释必须使用 Javadoc 规范,使用/**内容*/格式,不得使用 // xxx 方式。 说明:在 IDE 编辑窗口中,Javadoc 方式会提示相关注释,生成 Javadoc 可以正确输出相应注释;在 IDE 中…

Python面试题-交换两个数字的三种方法

Python实现两个数字交换解法1解法2解法3a6 b100 解法1 使用其他变量,最通用的方法 ca ab bc 解法2 不使用其他变量,利算法节省内存空间 aab ba-b aa-b 解法3 python 专有 a,b(b,a) #等号右边是一个元组 或者可以写为: a,bb,a print(a,b)

面试中海量数据处理总结

教你如何迅速秒杀掉:99%的海量数据处理面试题 前言 一般而言,标题含有“秒杀”,“99%”,“史上最全/最强”等词汇的往往都脱不了哗众取宠之嫌,但进一步来讲,如果读者读罢此文,却无任何收获&…

redis——旧版复制

Redis 的复制功能分为同步(sync)和命令传播(command propagate)两个操作: 同步操作用于将从服务器的数据库状态更新至主服务器当前所处的数据库状态。命令传播操作用于在主服务器的数据库状态被修改, 导致…

Linux(3)-网-ifconfig,ping,ssh

终端命令网-ping,ssh1. ifconfig -a2. ping3. ssh3.1安装3.2 连接3.3 配置登入别名防火墙端口号,todo1. ifconfig -a 查看IP地址, 还可以用于配置网口。 ifconfig -a 2. ping ping命令: 检测到IP地址的连接是否正常。命令开始后由本机发送数据包a&…

redis——相关问题汇总

什么是redis? Redis 本质上是一个 Key-Value 类型的内存数据库, 整个数据库加载在内存当中进行操作, 定期通过异步操作把数据库数据 flush 到硬盘上进行保存。 因为是纯内存操作, Redis 的性能非常出色, 每秒可以处理…