day11-元组与字典

1、元组Tuple与列表类似,不同之处在于元组的元素不能修改。

元组使用小括号,列表使用中括号。
元组可以查询,可以使用内置函数count、index。但是不能修改、增加、删除(儿子不能,孙子有可能)。
name = ('a','a','b')
print(name.count('a'))
2
可以索引,可以切片(步长)。
name = ('a','a','b')
print(name[2])
b

2、字典:
使用大括号来表示字典,前面是元素的名字,后面是元素的值(可以是字符,也可以是数字或其他任意类型),中间用冒号隔开。

info = {'name':'xiaowang','sex':'f','address':'中国北京'}
print(info)
{'name': 'xiaowang', 'sex': 'f', 'address': '中国北京'}

字典的查询效率比列表快,因为字典首先将key值进行hash并进行排序,当查询字典时只需查询key的hash值,而不需要从头进行循环,由于hash值进行了有序排序所以查询快
而列表不能对元素建立一个索引,所以只能从头循环查找

字典常见操作一:
2.1 按key值查询元素的值
>>> info['name']
'xiaowang'

2.2、get()查询
查询时,如果查询一个字典中不存在的元素,则程序会报错。为了不报错,可以使用get方法来查询字典
a.get('age') //不会返回任何值
a.get('age',0) //会将age的默认值设置为0,但是不会将默认值添加到字典中。
a.get('name','ddd') //会返回name的值abc,如果查询到了元素的值,则不会修改元素的值。

2.3、修改元素的值
>>> info['name'] = 'xiaozhang'
>>> info
{'name': 'xiaozhang', 'sex': 'f', 'address': '中国北京'}

2.4、添加元素的值
>>> info['high']= '170cm'

2.5、dict.setdefault(key, default)
许多时候我们需要往字典中的元素添加数据,我们首先要判断这个元素是否存在,不存在则创建一个默认值,存在则不变动。我们可以使用 dict.setdefault(key, default) 。
info.setdefault('sex','m')
print(info)
{'name': 'xiaowang', 'sex': 'f', 'address': '中国北京'}

2.6、删除元素的值,有del和clear、pop三种方法
>>> del info['high'] 删除high元素的值
>>> del info 删除整个info字典,如果del了整个字典后,再想在info中添加元素,则需要重新定义info字典。
>>> info.clear() 清空字典中所有元素的值,但是字典本身还在,只是成为了一个空字典
>>> info
>>> {}

pop(key) 函数,可以返回 key 对应的 value,并将该 key:value 键值对删除:

 

用pop()删除时可以指定字符串,如果要删除的key不存在时,则返回指定字符串,而不会报错
print(user.pop('tel','111'))
111
{'name': 'xiaozhang', 'sex': 'f', 'address': '中国北京'}

#popitem()会随机删除字典中的键值对
user.popitem()

2.7、创建字典
同 set 一样,字典也可以使用 dict 函数进行创建,参数是一个包含若干个二元组的元组(注意括号的数量):
dic = dict(((1,'Linux'), (2,'Vim')))
print(dic)
{1: 'Linux', 2: 'Vim'}

2.8、len()
测量字典中键值的个数
>>>dict = {'name':'zhangsan','sex':'m'}
>>>len(dict)
2

2.9、keys
返回一个包含字典所有key的列表
>>>dict = {'name':'zhangsan','sex':'m'}
>>>dict.keys()
dict_keys(['name','sex'])

>>>for i in dict.keys():
print(i)

2.10、values
返回一个包含字典中所有值的列表
>>>dict = {'name':'zhangsan','sex':'m'}
>>>dict.values()
dict_values(['zhangsan','m'])

>>>for i in dict.values():
print(i)

2.11、items
返回一个包含所有(键、值)元组的列表
>>> info.items()
dict_items([('name', 'xiaowang'), ('sex', 'f'), ('address', '中国北京')])

for i,j in temp:
    print('key:%s,value:%s'%(i,j))

key:name,value:xiaowang
key:sex,value:f
key:address,value:中国北京

user = {'name': 'xiaozhang', 'sex': 'f', 'address': '中国北京'}
print(list(user.keys()))
print(list(user.values()))
print(list(user.items()))

['name', 'sex', 'address']
['xiaozhang', 'f', '中国北京']
[('name', 'xiaozhang'), ('sex', 'f'), ('address', '中国北京')]

#获取字典的key和value有以下两种方法,建议用第一种方法效率高,因为第二种方法是先将字典转换成一个列表,再输出
user = {'name': 'xiaozhang', 'sex': 'f', 'address': '中国北京'}
for key in user:
print(key,user[key])

for k,v in user.items():
print(k,v)

2.12、has_key(在python2中有,3中没有这个方法,3中使用get()方法)
如果key在字典中,返回True,否则返回False
>>>dict = {'name':'zhangsan','sex':'m'}
>>>dict.has_key('name')
True
>>>dict.has_key('phone')
False

2.13、type(info)
可以查看info的类型是字典
<class 'dict'>

2.14、help(info)
可以查看info字典可以用的方法,info是字典的名字。

2.15、dict.fromkeys() 生成一个字典,用列表中的每一个元素作为一个key,可以指定value的默认值,如果不指定则value为None
user = ['tom','Jack','mike']
dict_user1 = dict.fromkeys(user,1)
print(dict_user1)
{'tom': 1, 'Jack': 1, 'mike': 1}

也可以将value指定成一个列表
user = ['tom','Jack','mike']
dict_user1 = dict.fromkeys(user,[1,2,3])
print(dict_user1)
{'tom': [1, 2, 3], 'Jack': [1, 2, 3], 'mike': [1, 2, 3]}


但是如果更改了任意一个value列表中的某个值,则所有value的值都会跟着更改

dict_user1['mike'][0]=0
print(dict_user1)
#{'tom': [0, 2, 3], 'Jack': [0, 2, 3], 'mike': [0, 2, 3]}

2.16、update()将两个字典进行合并
dict_1 = {'a':1,'b':2}
dict_2 = {'c':3,'d':4}
dict_1.update(dict_2)
print(dict_1)

#{'a': 1, 'b': 2, 'c': 3, 'd': 4}

2.17、copy()  浅copy
第2个字典copy第1个字典,修改字典中的值时,如果元素是不可变数据类型,则另一个字典不会随着改,如果元素是可变数据类型(列表、字典),则另一个字典也会随着改变。2个字典的id是不一样的,但是字典内元素的id是一样的,所以如果元素是列表或字典,当更改列表或字典内的值时,2个变量都是改变。

card_1 = {'name':'tom','acc':{'id':111,'balance':1000}}
card_2 = card_1.copy()
card_2['name'] = "tom's wife"
print(card_1)
print(card_2)
card_1['acc']['balance']-=100
print(card_1)
print(card_2)

{'name': 'tom', 'acc': {'id': 111, 'balance': 1000}}
{'name': "tom's wife", 'acc': {'id': 111, 'balance': 1000}}
{'name': 'tom', 'acc': {'id': 111, 'balance': 900}}
{'name': "tom's wife", 'acc': {'id': 111, 'balance': 900}}


2.18、copy.deepcopy(x)  深copy
#修改字典中的值时,其他字典不会随着改变,深copy是形成了两个完全独立的变量,变量id和变量内元素的id,以及可变元素内层的元素id都是不一样的
card_1 = {'name':'tom','acc':{'id':111,'balance':1000}}
card_2 = card_1.copy()
card_2['name'] = "tom's wife"
import copy
card_3 = copy.deepcopy(card_1)
card_3['name'] = 'mike'
print(card_1)
print(card_2)
print(card_3)
card_1['acc']['balance']-=100
print(card_1)
print(card_2)
print(card_3)

{'name': 'tom', 'acc': {'id': 111, 'balance': 1000}}
{'name': "tom's wife", 'acc': {'id': 111, 'balance': 1000}}
{'name': 'mike', 'acc': {'id': 111, 'balance': 1000}}
{'name': 'tom', 'acc': {'id': 111, 'balance': 900}}
{'name': "tom's wife", 'acc': {'id': 111, 'balance': 900}}
{'name': 'mike', 'acc': {'id': 111, 'balance': 1000}}

2.19、排序

d = {'Tom':20, 'Jack':22, 'Mike':28, 'Rose':30}
print(sorted(d.keys())) #将key值进行排序
['Jack', 'Mike', 'Rose', 'Tom']

print(sorted(d.values()))#将value值进行排序
[20, 22, 28, 30]

print(sorted(d.items()))#按key值对键值对进行排序
[('Jack', 22), ('Mike', 28), ('Rose', 30), ('Tom', 20)]

print(sorted(d.items(),key=lambda i:i[1])) #按value值对键值对进行排序
[('Tom', 20), ('Jack', 22), ('Mike', 28), ('Rose', 30)]

-----------------------------------------------------
例子:
将字典中的key键含有'k'元素的所有键值对删除。
由于在循环一个字典时,不能改变该字典的大小,所以不能直接在for循环的时候直接删除字典中的键值对,只能将需要删除的key先保存在一个列表中,再循环这个列表去删除字典中的键值对。

dic = {'k1':'v1','k2':'v2','k3':'v3','name': 'alex'}
L1 = []
for key in dic:if 'k' in key:L1.append(key)
for key in L1:del dic[key]
print(dic)

结果:{'name': 'alex'}

 

转载于:https://www.cnblogs.com/dxnui119/p/9830643.html

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

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

相关文章

vue问题四:富文本编辑器上传图片

vue使用富文本编辑器上传图片&#xff1a; 我是用的是wangEditor 富文本编辑器 demo:http://www.wangeditor.com/ 1).安装依赖:npm install wangeditor 2).我自己是创建了一个组件这样再用到的时候可以直接调用&#xff08;可能有更简单的方法&#xff09; <template lang&q…

vscode --- 快捷键格式化代码时,分号消失

问题复现 最近在vscode中,格式化代码(快捷键 alt shift F)时,分号会莫名奇妙的消失 对于习惯打分号的我来说,看起来很别扭… 解决方案. 我使用的是prettier这个插件来设置格式化的.安装方法如下: 点击左侧的: 搜索 prettier, 选择 Prettier - Code formatter 安装好了之后…

算法 --- [队列结构]二叉树的层次遍历

思路 使用队列: 初始化的时候,将root, push进队列q中循环队列q,当其中不为空时,取出第一个元素(q.shift),记为r若r.left不为空,将r.left推进q,若r.right不为空,将r.right推进q 记录层次: 4. 初始化设置i 0; 5. 在入队的时候,入队一个对象{r: root, i} 6. 出队时,使用es6的解…

Redis在windows下安装过程(转载)

转载自&#xff08;http://www.cnblogs.com/M-LittleBird/p/5902850.html&#xff09; 一、下载windows版本的Redis 官网以及没有下载地址&#xff0c;只能在github上下载&#xff0c;官网只提供linux版本的下载 官网下载地址&#xff1a;http://redis.io/download github下载地…

C# Socket网络编程精华篇

我们在讲解Socket编程前&#xff0c;先看几个和Socket编程紧密相关的概念&#xff1a; TCP/IP层次模型当然这里我们只讨论重要的四层 01&#xff0c;应用层(Application)&#xff1a;应用层是个很广泛的概念&#xff0c;有一些基本相同的系统级TCP/IP应用以及应用协议&#xff…

javascript --- [虚拟DOM] 初始化 实现

说明 本篇主要说明为什么要使用虚拟DOM技术,以及如何实现简单的虚拟dom您将会学到: 1.原生JS对DOM的操作 2.虚拟DOM的相关概念 3.DIFF算法的基础概念 为什么提出 -> DOM操作慢 我们使用createElement属性来创建一个最常见的div,看看一个最常见的DOM有多少个属性 <scri…

模块单元学习笔记(日志记录模块os模块sys)

一、日志记录模块 Logging 默认情况下&#xff0c;logging将日志打印到屏幕&#xff0c;日志级别大小关系为&#xff1a;CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET&#xff0c;当然也可以自己定义日志级别。 DEBUG&#xff1a;详细的信息,通常只出现…

tomcat8 进入不了Manager App 界面 403 Access Denied

准备 1.注释掉context.xml中的value属性 使用下面的命令&#xff1a; vim /usr/local/tomcats/tomcat-daily/webapps/manager/META-INF/context.xml 注释掉其中value节点 2.修改tomcat-users.xml文件 加入下面的配置 <role rolename"manager-gui" /><role …

MySQL中varchar最大长度是多少

一. varchar存储规则&#xff1a; 4.0版本以下&#xff0c;varchar(20)&#xff0c;指的是20字节&#xff0c;如果存放UTF8汉字时&#xff0c;只能存6个&#xff08;每个汉字3字节&#xff09; 5.0版本以上&#xff0c;varchar(20)&#xff0c;指的是20字符&#xff0c;无论存放…

salesforce lightning零基础学习(三) 表达式的!(绑定表达式)与 #(非绑定表达式)

在salesforce的classic中&#xff0c;我们使用{!expresion}在前台页面展示信息&#xff0c;在lightning中&#xff0c;上一篇我们也提及了&#xff0c;如果展示attribute的值&#xff0c;可以使用{!v.expresion}展示信息。 lightning在component中解析动态值的时候&#xff0c;…

网络协议各层概述

网络协议概述 OSI是一个开放性的通信系统互连参考模型&#xff0c;他是一个定义得非常好的协议规范。OSI模型有7层结构&#xff0c;每层都可以有几个子层。 OSI的7层从上到下分别是 7 应用层 6 表示层 5 会话层 4 传输层 3 网络层 2 数据链路层 1 物理层&#xff1b; 其中高层&…

javascript --- 实现对象的深拷贝

浅拷贝和深拷贝 浅拷贝: 只拷贝一层.当对象是复杂数据类型(Object、 Array)时,只拷贝引用深拷贝: 多层拷贝.复杂数据类型,会重新分配内存空间. 实现浅拷贝的2种方法 使用for ... in 实现 var obj {name: marron,age: 18,msg: {sex: "1" } } var o {}; for(let …

Qt与FFmpeg联合开发指南(二)——解码(2):封装和界面设计

与解码相关的主要代码在上一篇博客中已经做了介绍&#xff0c;本篇我们会先讨论一下如何控制解码速度再提供一个我个人的封装思路。最后回归到界面设计环节重点看一下如何保证播放器界面在缩放和拖动的过程中保证视频画面的宽高比例。 一、解码速度 播放器播放媒体文件的时候播…

Bzoj1051 受欢迎的牛

每一头牛的愿望就是变成一头最受欢迎的牛。现在有 N 头牛&#xff0c;给你 M 对整数 (A,B)&#xff0c;表示牛 A 认为牛 B 受欢迎。这种关系是具有传递性的&#xff0c;如果 A 认为 B 受欢迎&#xff0c;B 认为 C 受欢迎&#xff0c;那么牛 A 也认为牛 C 受欢迎。你的任务是求出…

javascript --- 文件上传即时预览 闭包实现多图片即时预览

使用javascript原生功能实现,点击上传文件,然后再网页上显示出来 1. 初级显示 1.1 准备一个input标签和一个img标签 <input typefile id"file"> <img id"preview" src"">1.2 js代码如下 // 将上传的图片显示到页面上function sho…

第一次作业:深入Linux源码分析进程模型

一.进程的概念 第一&#xff0c;进程是一个实体。每一个进程都有它自己的地址空间&#xff0c;一般情况下&#xff0c;包括文本区域&#xff08;text region&#xff09;、数据区域&#xff08;data region&#xff09;和堆栈&#xff08;stack region&#xff09;。文本区域存…

关于模型验证那点事儿

今天应笑笑老师之问&#xff0c;做了一个模型验证的例子&#xff0c;发现之前对这个东西的理解太片面&#xff0c;重新整理了一下思路 字段验证优先级高于类验证 什么是类验证呢&#xff1f;就是两个字段组合的验证&#xff0c;比如你Admin不允许修改密码&#xff0c;你修改密码…

Win10安装MySQL5.7.22 解压缩版(手动配置)方法

1.下载地址&#xff1a;https://dev.mysql.com/downloads/mysql/5.7.html#downloads 直接点击下载项 下载后&#xff1a; 2.可以把解压的内容随便放到一个目录&#xff0c;我的是如下目录&#xff08;放到C盘的话&#xff0c;可能在修改ini文件时涉及权限问题&#xff0c;之后我…

Elemant-UI日期范围的表单验证

Form 组件提供了表单验证的功能&#xff0c;只需要通过 rules 属性传入约定的验证规则&#xff0c;并将 Form-Item 的 prop 属性设置为需校验的字段名即可。但是官网的示例只有普通日期类型的验证&#xff0c;没有时间范围的验证。 一开始&#xff0c;我认为时间时间范围的是一…

node --- [express项目] 开发环境下使用morgan控制台输出访问信息

说明 源代码记录、遗忘回顾 process.env node中提供了一个process.env接口用于访问计算机中的系统环境变量. 可以利用以上属性来区分当前的环境是开发环境还是生产环境,代码如下: if (process.env.NODE_ENV development) {console.log(当前环境是开发环境) } else {consol…