一、元祖

  1.用途:记录多个值,当多个值没有改变的需求,元祖不能修改,但元祖里的数据的数据可以修改。

  2.定义方式:在()内用逗号分隔开多个任意值。

    思考:如果定义一个只有一个一个值的元祖。 # t = (1, )

 常用操作:

  优先掌握:

 # 索引取值
t = (1, 2, 3, 2, 3, 2)
print(t[1])
print(t[-2]) # 切片
print(id(t))
nt = t[:-1:]
print(nt, id(nt)) # 长度(item元素个数)
print(len(t)) # 元组内置方法
print(t.count(2)) # 该数据集合可以存放相同数据
print(t.index(2, 2, 3))

元祖案例:

 # 提前拥有一个老师列表,打算开除,如果是校长亲友团,免开

 # 原始列表为list类型
# 手动输入是否是亲友团,决定是否能开除() teas = ['Bob', 'Alex'] friends = input("亲友团[0, 1]:") if friends == '':
teas = tuple(teas) # => 异常处理
# 判断teas对象是否是tuple类型
if not isinstance(teas, tuple): # 老师是否是亲友团,不是就开除
teas.clear() for t in teas:
print("在职老师:%s" % t) # 案例二
# 元组中的数据一定不能改变,但是元组中的数据(可变类型)的数据可以改变
t1 = (1, 2, "abc", True, (1, 2)) # t1永远无法改变 t2 = (1, 2, [])
print(t2, type(t2), id(t2), id(t2[2]))
t2[2].extend((10, 20))
print(t2, type(t2), id(t2), id(t2[2]))

二、字典类型

特别了解:dict是python中仅存的mapping类型
 1.声明
dict的key:可以为所不可以变类型:int float tuple str bool None
dict的value:可以为所有数据类型
注:key具有唯一性(重复会覆盖旧值),value可以重复
例:
dic = {1: None, None: None, 3.14: None,
True: None, 'abc': None, (1,): None,
None: 12345
}
print(dic)

2.1用途:记录多个值,每一个值都是对应的key用来描述value的作用

2.2定义方法:在{}内用逗号分隔开多个:key-value其中value可以定

义可以使任意类型,而可以必须是不可变的类型,通常情况下应该是

str类型。

2.3字典无序存储数据,无索引与切片,用key来取值

2.4优先掌握的操作

①.按key存取值:可存、可取

②.长度len()

③.成员运算 in not in

4④删除:del()   pop() 删除对应的值并返回value  popitem()随机删除,有返回值

⑤.循环:

 #示例
d={'name':'zhaokang','age':18}
#取key
#方法一
for i in d:
print(i)
#方法二
for i in d.keys():
print(i) #取Value
for i in d.values:
print(i) #取key-value
for k,v in d.item():
print(k,v)

2.5字典的内置方法

 #增删改查
dic={}
#增:key不存在
#方法一
dic['name']='Mac'
print(dic)
结果是:{'name':'Mac'}
#方法二
#update添加的参数字典,与dic 可以重复,就是更新值,新key就是新增
dic.update({'a':100,'c':300})
print(dic)
结果是:{'a':100,'b':30,'c':300}
#方法三 setdefault 有两个参数 ①key ②default
#字典中已经存在key则不做任何操作,返回的结果是已存在的Value
#如果字典不存在key则添加,返回新的value
#一
dic = {'name':'zhaokang'}
dic.setdefault('name','ZhaoKang')
print(dic)
输出结果是:{'name':'zhaokang'} 返回值是 zhaokang
#二
dic = {'name':'zhaokang'}
dic.setdefault('name1','ZhaoKang')
print(dic)
输出结果是:{'name1':'ZhaoKang'} 返回值是 ZhaoKang
#改:key已经存在
dic['name']='Big Mac'
print(dic)
输出结果是:{'name':'Big Mac'} #查
print(dic['name'])
输出结果是:{'name':'zhaokang'} #删
#方法一
del dic['name']
print(dic)
输出结果是:{}
#二 据key删除指定对象,并返回删除的对象的value
print(dic.pop(['name']))
输出结果是:{}
#三 随机删除
print('dic.popitems()')
输出结果是:{}

2.6需要掌握的操作:

   #get 当需要取得值得key不在字典中则不会报错返回默认值None
#如果需要取得值得key存在字典中则取到value
dic={'a':20,'b':30}
res=dic.get('c') # 拥有默认值.None,可以避免报错
print(res)
输出结果是:None
dic = {'a': 20, 'b': 30}
res = dic.get('b') # 拥有默认值.None,可以避免报错
print(res)
输出结果是:30 {}.fromkeys('n',20)
输出结果是:{'n': 20} #copy:
#浅copy:只做第一层copy,内部的成员地址还是原来的地址
dic = {'a': 20, 'b': 30}
print(dic.ccopy())
输出结果是:{'a': 20, 'b': 30}
 # 字典的定义:{} | dict()
# 字典的常用操作:增删改查
# 字典的内置方法:
# 字典的循环(迭代) dic = {'a': 10, 'b': 20, 'c': 30}
# 直接for循环(遍历)字典得到的是key
for k in dic:
print(k, dic[k]) # 能不能只循环值
values = dic.values()
print(values, type(values))
# 存放key的集合
keys = dic.keys()
print(keys, type(keys))
# 存放key-value的键值对关系
k_vs = dic.items()
print(k_vs, type(k_vs)) # dic.values() | dic.keys() | dic.items() 不是原生list,不能直接索引取值,但可以for循环取值
# vs = list(values)
# print(vs[1])
# for v in vs:
# print(v) for v in values:
print(v)
print()
for k in keys: # 跟直接遍历字典是一样的
print(k) print()
# ***** 同时遍历k-v
for k, v in dic.items():
print(k, v) ls = ['Owen', 'owen', 'Egon', 'LiuXX', 'Liuxx', 'egon', 'egon']
name_dic = {}
for name in ls:
name = name.lower()
# name已存在,不管,不存在,初始化指定key:name值为1
name_dic.setdefault(name, 0)
name_dic[name] += 1
print(name_dic)

字典循环与案例

三、集合

#定义与声明:
#什么事set:
#①单列数据集合:str,list,tuple,set
#双列:dict
②无序存储:无key无index,无法取值
③可变数据类型,内部可以存放任意数据类型,但数据具有唯一性
#{}代表空字典,set()用来表示空集合
s1=set()
print(s1,type(s1))
s2=set('abc')
print(s2,type(s2)) 2.内置方法与使用 集合运算 ($ | ^ - > < ==)
p_set = {'a', 'b', 'c', 'egon'}
l_set = {'x', 'y', 'z', 'egon'}
# 交集 & intersection
res = p_set & l_set
print(res)
res = p_set.intersection(l_set)
print(res) # {'egon'} # 并集 | union
res = p_set | l_set
print(res)
res = p_set.union(l_set)
print(res) # {'z', 'c', 'y', 'x', 'b', 'a', 'egon'} #差集 - difference
res = p_set - l_set
print(res) # {'a', 'b', 'c'}
res = l_set.difference(p_set)
print(res) # {'x', 'z', 'y'} # 对称差集 ^ symmetric_difference
res = p_set ^ l_set
print(res)
res = p_set.symmetric_difference(l_set)
print(res) # {'y', 'a', 'b', 'x', 'z', 'c'} # 添加删除操作
s = set()
s.add('abc')
s.add('xyz')
print(s)
res = s.pop() # 随机删除一个ele元素
print(res)
if 'xyz' in s:
s.remove('xyz') # 有ele删除,无ele抛异常 #循环 利用set 去重
classes = set()
for _, cless in class_map:
classes.add(cless)
classes = list(classes)
print(classes) # 了解:父子set
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)
print(sup_set < sub_set)
print(temp_set == sub_set) # 两个set是否没有交集
res = flag_set.isdisjoint(temp_set)
print(res)
res = temp_set.isdisjoint(sup_set)
print(res)
 # 需求:
# 1.多少人参加了选课: ['owen', 'egon', 'liuxx']
# 2.都选了哪些课程: ['python', 'linux', 'java']
# 利用逻辑代码去重
names = []
for name, _ in class_map:
# 判断列表中是否已存在,不存在才添加
if name not in names:
names.append(name)
print(names)

案例

python 元祖字典集合的更多相关文章

  1. python-列表元祖字典集合

    列表 list = ["a", "b", "c", "d"]元祖 tup = (1, 2, 3, 4, 5 ) 1.元组 ...

  2. Python学习笔记---切片 列表 元祖 字典 集合

    列表[1,2,3,2]#[] 元祖(1,2,3,2)#() 字典{1:2,3:2}#{} 集合{1,2,3,2}#{} 1,集合与列表的区别,集合里不能有重复元素 2.字典与集合的区别,都是用花括号表 ...

  3. Python基础5:列表 元祖 字典 集合

    [ 列表] 列表(list)是Python以及其他语言中最常用到的数据结构之一.Python使用使用中括号 [ ] 来解析列表. 列表是可变的(mutable)——即:可以改变列表的内容. 相关操作: ...

  4. Python基础5:列表 元祖 字典 集合 Json

    [ 列表] 列表(list)是Python以及其他语言中最常用到的数据结构之一.Python使用使用中括号 [ ] 来解析列表. 列表是可变的(mutable)——即:可以改变列表的内容. 相关操作: ...

  5. 06 元祖 字典 集合set

    元组 定义: ti=() print(ti,type(ti)) 参数:for可以循环的对象(可迭代对象) t2=tuple(") # ('1', '2', '3') <class 't ...

  6. python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍

    目录 python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍.md 一丶字典 1.字典的定义 2.字典的使用. 3.字典的常用方法. python学习第八讲,python ...

  7. python学习第七讲,python中的数据类型,列表,元祖,字典,之元祖使用与介绍

    目录 python学习第七讲,python中的数据类型,列表,元祖,字典,之元祖使用与介绍 一丶元祖 1.元祖简介 2.元祖变量的定义 3.元祖变量的常用操作. 4.元祖的遍历 5.元祖的应用场景 p ...

  8. python学习第六讲,python中的数据类型,列表,元祖,字典,之列表使用与介绍

    目录 python学习第六讲,python中的数据类型,列表,元祖,字典,之列表使用与介绍. 二丶列表,其它语言称为数组 1.列表的定义,以及语法 2.列表的使用,以及常用方法. 3.列表的常用操作 ...

  9. what's the python之基本运算符及字符串、列表、元祖、集合、字典的内置方法

    计算机可以进行的运算有很多种,运算按种类可分为算数运算.比较运算.逻辑运算.赋值运算.成员运算.身份运算.字符串和列表的算数运算只能用+和*,字典没有顺序,所以不能进行算数运算和比较运算.比较运算中= ...

随机推荐

  1. 通过JavaScript调用SOAP终结点执行实体消息

    关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复148或者20150813可方便获取本文,同时可以在第一时间得到我发布的最新的博文信息,follow me! 利用OData终结点可以方便的对 ...

  2. Dynamics 365-ExecuteWorkflowRequest

    一般是通过对CRM上的数据进行手动操作,来触发Workflow,但是如果碰到数据量比较大的时候,纯手动操作无疑是一个耗时费力的事.这个时候,可以通过使用ExecuteWorkflowRequest来实 ...

  3. 使用ip开头的工具,而不是只会ifconfig

    结论: 1.使用ip 开头的工具,比ifconfig显示的信息更多,并且支持的功能更强大. 2.常用的功能有: 显示接口基本信息: ip link show dev eth0 设置端口up/down: ...

  4. Dynamics AX 2012 R2 电子邮件广播错误 0x80040213

    Dynamics AX 2012 R2 电子邮件广播错误 0x80040213 今天Reinhard在新环境做邮件广播测试时,发现无法发送邮件,并报以下错误: 类"CDO.Message&q ...

  5. Netty学习笔记(四) 简单的聊天室功能之服务端开发

    前面三个章节,我们使用了Netty实现了DISCARD丢弃服务和回复以及自定义编码解码,这篇博客,我们要用Netty实现简单的聊天室功能. Ps: 突然想起来大学里面有个课程实训,给予UDP还是TCP ...

  6. 牛客网:java入门实现遍历目录

    项目介绍 遍历目录是操作文件时的一个常见需求.比如写一个程序,需要找到并处理指定目录下的所有JS文件时,就需要遍历整个目录.该项目教会你如何使用流式编程和lambda表达式,帮助你进一步熟悉java8 ...

  7. 18-10-31 Scrum Meeting 3

    1.会议照片 2.每人的工作 昨天完成的工作   1 制定配置 修改配置 查询配置这三个接口   2 3 获取单词对应的中文释义   4 完成测验的部分接口   5 后端对接计划的接口   6 剩余的 ...

  8. SQL Server GUID 数据迁移至MongoDB后怎样查看?

    关键字:SQL Server NEWID():BSON:MongoDB UUID 1.遇到的问题和困惑 SQL Server中的NEWID数据存储到MongoDB中会是什么样子呢?发现不能简单的通过此 ...

  9. Ubuntu 16.04 启用 点击Launcher图标,窗口实现最小化 功能

    安装了Ubuntu之后,要是每次都点击最小化按钮来实现窗口的最小化,操作起来很不方便,那么怎么样才能方便操作呢, Ubuntu 16.04 本身支持 点击应用程序Launcher图标实现最小化 功能, ...

  10. RHEL6 删除软RAID

    停止使用RAID: 1.umount raid组上的硬盘的所用的分区 若使用raid组创建vg,需要删除或去激活VG 2.停止raid服务 mdadm -S /dev/md0 3.清除MBR # md ...