DAY6 元组、字典与集合
一、元组
定义:t1 = (1, 2) # t1 = tuple((1,2))
特点:有序存储、可存放多个数据、不可变(内部可以包含可变对象,可变对象已久可变)
应用场景:将不允许操作的列表可以转化为元组,将允许操作的元组转化为列表
1.元组的定义
t1 = () # t1 = tuple()
print(t1,type(t1)) # () <class 'tuple'>
1.1 tuple() # 参数为for可以循环的对象(可迭代对象)
例如:t2 = tuple("123")
print(t2, type(t2)) # ('1', '2', '3') <class 'tuple'>
t3 = tuple([1, 2, 3])
print(t3, type(t3)) # (1, 2, 3) <class 'tuple'>
t4 = tuple((7, 8, 9))
print(t4, type(t4)) # (7, 8, 9) <class 'tuple'>
1.2 定义一个只有一个元素的元组
t1 = tuple(1, )
t1 = tuple([1])
2.元组的操作
1.索引取值
t = (1, 2, 3, 2, 3, 2)
print(t[1])
print(t[-2])
2.切片
nt = t[:-1:]
3.长度(item元素个数)
print(len(t))
4.元组内置方法
print(t.count(2)) # 该数据集合可以存放相同数据
print(t.index(2, 0, 3))
二、字典
定义:d1 = {'a': 10, 'b': 20} # d1 = dict({'a': 10, 'b': 20})
特点:无序,存放多个值,可变 => 通过key取值
1.声明
dict的key:可以为所以不可变类型:int float tuple str bool None, 一般就采用字符串
dict的value:可以为所以数据类型
key具有唯一性(重复会覆盖旧值),value可以重复
2.字典的增删改查
字典无序存储数据,无索引与切片,用key来取值
2.1 增、改
d1[key] = value: key存在就是改,不存在就是增
update({'a': 100, 'c': 300}): key有更新,无新增
2.2 查
d1[key]: 取,如果key不存在就报错,所以用get(key, defalut)
2.3 删
pop(key): 根据key删且返回对应value
3.get取值
dic = {'a': 10, 'b': 20}
print(dic['c']) # KeyError
res = dic.get('c') # 拥有默认值,None,可以避免错误
print(res) # None
res = dic.get('d', 'key不存在') # 可以自定义默认值
print(res) # key不存在
4.复制
newDic = dic.copy()
print(newDic)
浅copy:只做第一层copy,内部的成员地址还是原来的地址
5.随机删除
dic.popitem()
返回值是(key,value)
6.定义一个空字典
第一个参数:keys:list|tuple|str,第二个参数:统一的默认value
d10 = {}.fromkeys(['a', 'b', 'c'], '')
print(d10) # {'a': '', 'b': '', 'c': ''}
7.
key存在,不操作,不存在设置key=default
dic.setDefault(key, default)
三、集合set
1.定义
s1 = set() # {}代表空字典,用set()来创建空集合
s2 = set({1, 2, 3})
2.重点:数据具有唯一性
1.单列数据集合:str,list,tuple,set 双列:dict
2.无序存储:无key无index,无法取值
3.可变数据类型,内部可以存放任意类型数据,但数据具有唯一性
3.内置方法与使用 - 集合间的运算 (& | ^ - > < ==)
p_set = {'a', 'b', 'c', 'egon'}
l_set = {'x', 'y', 'z', 'egon'}
3.1交集 &
res = p_set & l_set
print(res)
res = p_set.intersection(l_set)
print(res) # {'egon'}
3.2并集
res = p_set | l_set
print(res)
res = p_set.union(l_set)
print(res) # {'z', 'c', 'y', 'x', 'b', 'a', 'egon'}
3.3差集
res = p_set - l_set
print(res) # {'a', 'b', 'c'}
res = l_set.difference(p_set)
print(res) # {'x', 'z', 'y'}
3.4对称差集
res = p_set ^ l_set
print(res)
res = p_set.symmetric_difference(l_set)
print(res) # {'y', 'a', 'b', 'x', 'z', 'c'}
3.5 增、删
1.添加
s = set()
s.add('abc')
s.add('xyz')
2.删
2.1 res = s.pop() # 随机删除一个ele元素
2.2 if 'xyz' in s:
s.remove('xyz') # 有ele删除,无ele抛异常
4.了解
sup_set = {1, 2, 3, 4, 5}
sub_set = {1, 2, 3}
temp_set = {3, 2, 1}
flag_set = {7, 8, 9}
print(sup_set > sub_set) # True
print(sup_set < sub_set) # False
print(temp_set == sub_set) # True
# 两个set是否没有交集
res = flag_set.isdisjoint(temp_set) # True
DAY6 元组、字典与集合的更多相关文章
- day 07 元组,字典和集合等数据类型介绍
元组:就是一个不可变的列表 1.用途,当我们需要记录多个值,并且没有更改的需求的时候,应该使用元组 2定义方式:使用,在 ( ) 中分隔开多个任意类型的值 注:t=("egg",) ...
- python基础之02列表/元组/字典/set集合
python中内置的数据类型有列表(list)元组(tuple)字典(directory). 1 list list是一种可变的有序的集合.来看一个list实例: #第一种方法: >>&g ...
- python学习Day6 元组、字典、集合set三类数据用法、深浅拷贝
一.深浅拷贝 1. 值拷贝 ls1 = ls2 不开辟空间,指针跟着走.(直接将ls1中存放的地址拿过来,内存中不会开辟新的空间,所以你怎么变,我也跟着变.)(ls1内部的所有类型的值发生改变,l ...
- day6作业(元组,字典,集合)
默写: 1.元组 字典 集合 列表 各自的特点 2.字典添加 删除 修改 循环 必做: 1.餐厅提供了五种不同的菜,使用元组来存储他们,并循环打印出所有菜名,要求用户输入新加的菜名,加入到菜单中,并重 ...
- Python黑帽编程2.3 字符串、列表、元组、字典和集合
Python黑帽编程2.3 字符串.列表.元组.字典和集合 本节要介绍的是Python里面常用的几种数据结构.通常情况下,声明一个变量只保存一个值是远远不够的,我们需要将一组或多组数据进行存储.查询 ...
- python基础知识3——基本的数据类型2——列表,元组,字典,集合
磨人的小妖精们啊!终于可以归置下自己的大脑啦,在这里我要把--整型,长整型,浮点型,字符串,列表,元组,字典,集合,这几个知识点特别多的东西,统一的捯饬捯饬,不然一直脑袋里面乱乱的. 一.列表 1.列 ...
- Python基础-列表_元组_字典_集合
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...
- Python成长笔记 - 基础篇 (三)python列表元组、字典、集合
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 一.列表和元组的操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义 ...
- python中列表 元组 字典 集合的区别
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...
- python数据类型之元组、字典、集合
python数据类型元组.字典.集合 元组 python的元组与列表类似,不同的是元组是不可变的数据类型.元组使用小括号,列表使用方括号.当元组里只有一个元素是必须要加逗号: >>> ...
随机推荐
- Linux网络 - 数据包的接收过程(转)
https://segmentfault.com/a/1190000008836467
- Gym 102028C - Supreme Command - [思维题][2018-2019 ACM-ICPC Asia Jiaozuo Regional Contest Problem C]
题目链接:https://codeforces.com/gym/102028/problem/C Lewis likes playing chess. Now he has n rooks on th ...
- Gym 101775C - Traffic Light - [思维题]
题目链接:http://codeforces.com/gym/101775/problem/C 题意: 给出 $N$ 个红绿灯,又给出 $N+1$ 个距离 $S_i = S_0,S_1, \cdots ...
- jmeter安装与环境变量配置
因jmeter是java开发的,要想运行java开发的程序,必须先下载JDK一.jdk 1.下载jdk jdk下载地址:https://www.oracle.com/technetwork/java ...
- ES6 模块
概述 在 ES6 前, 实现模块化使用的是 RequireJS 或者 seaJS(分别是基于 AMD 规范的模块化库, 和基于 CMD 规范的模块化库). ES6 引入了模块化,其设计思想是在编译时 ...
- 集合 & 深浅copy
集合: 特点:集合是可变的数据类型,但他里面的元素必须是不可变的数据类型,无序,不可重复. 创建: set1 = set({1,2,3}) 或者直接创建set2 = {1,2,3} 集合的增删查: 增 ...
- Cutterman - 最好用的切图工具
Cutterman - 最好用的切图工具 http://www.cutterman.cn/zh/cutterman
- Python3学习之路~5.9 xml处理模块
xml是实现不同语言或程序之间进行数据交换的协议,跟json差不多,但json使用起来更简单,不过,以前在json还没诞生的时候,大家只能选择用xml,至今很多传统公司如金融行业的很多系统的接口还主要 ...
- Centos下,Docker部署Yapi接口管理平台(详细得令人发指)
接口测试的工具很多,公司引进了接口管理平台Yapi,自己尝试直接搭建,从安装Nodejs到配置MongoDB数据库,再到安装yapi的时候,遇到浏览器打开本地服务器Ip地址后,没有显示部署内容...没 ...
- JUnit单元测试代码
package com.storage.test; import org.junit.Before; import org.junit.Test; import org.springframework ...