一、元祖

  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. ASP.MVC学习资源总结

    自己动手写一个简单的MVC框架(第一版) 自己动手写一个简单的MVC框架(第二版) ASP.Net请求处理机制初步探索之旅 - Part 1 前奏 ASP.Net请求处理机制初步探索之旅 - Part ...

  2. Flex Builder 4.6切换语言

    一.修改Flex builder 1.用无格式编辑器打开FlashBuilder.ini 2.把zh_CN替换成"en_US" 二.修改MyEclipse插件 1.用无格式编辑器打 ...

  3. Centos7上安装docker (转)

    Centos7上安装docker Docker从1.13版本之后采用时间线的方式作为版本号,分为社区版CE和企业版EE. 社区版是免费提供给个人开发者和小型团体使用的,企业版会提供额外的收费服务,比如 ...

  4. LeetCode算法题-Quad Tree Intersection(Java实现)

    这是悦乐书的第260次更新,第273篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第127题(顺位题号是558).四叉树是树数据,其中每个内部节点恰好有四个子节点:top ...

  5. OKR相关4本书,好书3本

    最近几年看过4本OKR相关的书,有3本是4星.其中第一本是最近看的,剩下3本是2017年看的. OKR源自德鲁克和格鲁夫,跟谷歌是天作之合:4星|<这就是OKR> 4星|<OKR实践 ...

  6. Docker: Harbor一些小知识

    镜像文件上传到私有仓库harbor后,镜像的物理存储位置在哪里? 这些信息记录在docker-compose.yml里,通过观察发现 镜像存储在了宿主机的 volumes: - /data/regis ...

  7. 英语进阶系列-A05-英语升级练习三

    古诗背诵 要求:认真背诵和朗读,然后翻译成现代文,并绘制图像描述图中的意向,时间限制到10 minutes.另外,从中找出英文单词,并记录. 例如:慈母 = kind mother,手 = hand, ...

  8. org.springframework.web.context.support.XmlWebApplicationContext.refresh Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreatio

    错误异常: 11-Apr-2019 18:07:14.006 警告 [RMI TCP Connection(5)-127.0.0.1] org.springframework.web.context. ...

  9. Docker Selenium

    SeleniumHQ官方项目:https://github.com/seleniumHQ/docker-selenium 项目目前快速迭代中. Docker 一般叫docker容器,一个可爱的鲸鱼,上 ...

  10. TensorRT&Sample&Python[fc_plugin_caffe_mnist]

    本文是基于TensorRT 5.0.2基础上,关于其内部的fc_plugin_caffe_mnist例子的分析和介绍. 本例子相较于前面例子的不同在于,其还包含cpp代码,且此时依赖项还挺多.该例子展 ...