一、元组

1、定义:参数为for可以循环的对象

t1 = (1, 2)
     t2 = tuple((1, 2))
     t3 = (1, )        #定义一个只有一个值的元组

2、常用操作:

2.1、索引

元组是有序存储,所以可以以索引取值

t(1,2,3,4,5)

print(t[1])

print(t[-2])

2.2、长度(item元素个数)

print(len(t))

2.3、切片

t=(1,2,3,2,3,2)

nt = t[:-1:]

print(nt)       #(1,2,3,2,3)

3、元组的内置方法:

print(t.count(2))    #统计2的个数,该数据集合可以存放相同数据

t=(1,2,3,2,3,2)

print(t.index(2,2,3))   #报错,顾头不顾尾,所以找不到2

元组小结:有序存储 ,可存放多个数据 , 不可变(内部可以包含可变对象,可变对象可以改变)

它可以将不允许操作的列表可以转化为元组,将允许操作的元组转化为列表

二、字典

1、定义:在大括号内用逗号分隔开,以一个key对应一个value存储

dic={'a':10,'b':20}

2、常用操作:

2.1、增加:key不存在

dic['name'] = 'Mac'

2.1、该:key存在

dic['name'] = 'Big Mac'   #将原先的Mac改为Big Mac

2.2、查value:

print(dic['name'])     #查找'name'对应的value值

2.3、删除:

del dic['name']

3、内置方法:

3.1、   get取值(重点)*****

例:dic = {'a':10,'b':20}

print(dic['c'])    #KeyError 即c不存在dic中就会报错

res = dic.get('c')    #拥有默认值None,可以避免错误,返回None

res = dic.get('d',key不存在)   #返回key不存在

3.2、增加:添加的参数字典,与dic可以重复,如果重复就是更新,如果不重复则新增

print(dic.update({'a':100,'c':300}))     #{'a':100,'b':20,'c':300},即a的值更新了,新加了c

3.3、删除:

res = dic.pop('c')      #根据key删除指定对象,并返回删除对象的value

print(red)      #300

3.4、复制:(浅拷贝、深拷贝)

d1 = {'list':[1,2]}

d2 = d1.copy()         #d1,d2的地址不一样,但是内部成员的地址不变,即只做第一层copy(浅copy)

d1['list'].append('abc')

print(d2)        # {'list':[1,2,'abc']}

3.5、随机删除:

print(dic.popitem())        #随机删除字典里的一个值,返回的是被删除的(key:value)

3.6、定义空字典:第一个参数key可以是list,tuple,str,第二个参数是统一的默认value

d1 = {}.fromkeys(['a','b','c'],'')

print(d1)     #{'a':'','b':'','c':''}

3.7、setdefault的用法

d.setdefault('teas',[])    #在d中,如果有teas这个key,setdefault相当于什么都没做

#如果没有,就将第二个参数(默认值)传给teas存放到d中

字典小结:字典中的key可以为所有不可变类型:int float tuple str bool None,但是一般采用字符串

value可以是任意类型(注:key具有唯一性,即重复会覆盖旧值,而value可以重复)

三、集合

1、定义:s = set()

2、常用操作与内置方法

2.1、交集&

p_set = {'a','b','c','egon'}

l_set = {'x','y','z','egon'}

res = p_set & l_set

或 res = p_set.intersection(l_set)

print(res)                   #{'egon'}

2.2、并集|

res = p_set | l_set

或res = p_set.union(l_set)

print(res)               #{'x','y','z','a',b','c','egon'}

2.3、差集

res = p_set - l_set

print(res)    #{'a','b','c'}

或res = p_set.difference(l_set)

print(l_set - p_set)   #{'x','y','z'}

2.4、对称差集^

res = p_set ^ l_set

或res = p_set.symmetric_difference(l_set)

print(res)      #{'a','x','b','c','y','z'}

2.5、增加

s = set()

s.add('abc')

s.add('xyz')

print(s)         #{'abc','xyz'}

2.6、删除

res = s.pop ()

print(res)       #随机删除一个元素

if 'xyz' in s:

s.remove('xyz')    #有就删除,没有就报错

3、了解

1、父子set

set1 = {1,2,3,4,5,6}

set2 = {1,2,3}

set3 = {7,8,9}

print(set1 > set2)     #True

print(set2 == set3)    #False

2、两个set是否没有交集

res = set3.isdisjoint(set2)

print(res)                  #没有交集,True

res = set2.isdisjoint(set1)

print(res)                  #有交集,False

集合小结:集合是无序存储,没有key,没有index,无法取值;

可变数据类型,内部可以存放任意类型数据,但数据具有唯一性

DAY06、元组、字典、集合的更多相关文章

  1. python中列表 元组 字典 集合的区别

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...

  2. **python中列表 元组 字典 集合

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...

  3. python_列表——元组——字典——集合

    列表——元组——字典——集合: 列表: # 一:基本使用# 1.用途:存放多个值 # 定义方式:[]内以逗号为分隔多个元素,列表内元素无类型限制# l=['a','b','c'] #l=list([' ...

  4. 元组/字典/集合内置方法+简单哈希表(day07整理)

    目录 二十三.元组内置方法 二十四.字典数据类型 二十五 集合内置方法 二十五.数据类型总结 二十六.深浅拷贝 补充:散列表(哈希表) 二十三.元组内置方法 什么是元组:只可取,不可更改的列表 作用: ...

  5. python3笔记十八:python列表元组字典集合文件操作

    一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle  #数据持久性模块 #封装的方法def OptionData(data,path):    # ...

  6. day_6深浅拷贝,元组字典集合类型定义和各种操作方法

    首先我们来讲一下深浅拷贝 1:值拷贝,假设一个列表等于L1 再定义一个L2=L1  这样就是值拷贝 L2只是存的L1存列表的地址,所以当L1发生改变,L2也随之改变 2:浅拷贝,L2=L1.copy( ...

  7. Python 基础-python-列表-元组-字典-集合

    列表格式:name = []name = [name1, name2, name3, name4, name5] #针对列表的操作 name.index("name1")#查询指定 ...

  8. Python数据类型-布尔/数字/字符串/列表/元组/字典/集合

    代码 bol = True # 布尔 num = 100000000; # 数字 str = "fangbei"; # 字符串 str_cn = u"你好,方倍" ...

  9. python的学习笔记01_4基础数据类型列表 元组 字典 集合 其他其他(for,enumerate,range)

    列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素 特性: 1.可存放多个值 2.可修改指定索引位置对应的值,可变 3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问 ...

  10. python 列表 元组 字典 集合

    列表 lst = [i for i in range(10)] 切片 # 把下标小于2的显示出来 print(lst[:2]) # 把10个数有大到小输出 print(lst[::-1]) # 把下标 ...

随机推荐

  1. docker-1-环境安装及例子实践

    1.安装go 先新建一个Go的工作空间文件夹,文件夹路径建议放在$HOME下: userdeMacBook-Pro:~ user$ cd $HOME userdeMacBook-Pro:~ user$ ...

  2. ogg BR – BOUNDED RECOVERY

    BR – BOUNDED RECOVERY 适用于 Extract 进程(仅适用于 Oracle数据库) 使用 BR 参数可以控制 GoldenGate 的 Bounded Recovery (BR) ...

  3. 禁止 gVim 在 Linux 下自动生成 undo 文件 *.un~

    在配置文件 .vimrc 中加入配置项, set noundofile 完.

  4. Python 的全局变量

    结论: Python 的全局变量只在本文件中生效. 定义全局变量的文件 G.py # define some global variable A = 1 B = 2 C = 3 def fuck(a= ...

  5. Ubuntu16.04环境安装jenkins

    前提:系统必须安装jdk 如果没有安装可通过如下命令安装: sudo add-apt-repository ppa:openjdk-r/ppa sudo apt update sudo apt ins ...

  6. AI R-CNN目标检测算法

    Region-CNN,简称R-CNN,是首次将深度学习应用于目标检测的算法. bounding box IOU 非极大值抑制 selective search 参考链接: https://blog.c ...

  7. Jmeter自定义Java请求,继承AbstractJavaSamplerClient

    首先,使用Eclipse新建一个项目,然后从Jmeter的lib/ext目录下中拷贝ApacheJMeter_java.jar和ApacheJMeter_core.jar两个文件,然后引入这两个JAR ...

  8. sklearn 数据预处理1: StandardScaler

    作用:去均值和方差归一化.且是针对每一个特征维度来做的,而不是针对样本. [注:] 并不是所有的标准化都能给estimator带来好处. “Standardization of a dataset i ...

  9. 【原创】自己动手写一个能操作redis的客户端

    引言 redis大家在项目中经常会使用到.官网也提供了多语言的客户端供大家操作redis,如下图所示 但是,大家有思考过,这些语言操作redis背后的原理么?其实,某些大神会说 只要按照redis的协 ...

  10. 微信小程序获取formId时提示"the formId is a mock one"

    微信小程序使用模板消息需要使用表单提交 formId,因此进行了简单的代码测试,在 wxml 文件中创建 form 对象,并在 form 标签中声明属性 report-submit="tru ...