一、元组

1.元组基础

  1)定义:不可变的‘列表’,定义方式(元素1,元素2.......)

  2)用途:存多个值,但是只能读不能写

  注意:元组的不可变指的是元组内元素id的不可变

t = (11,2,3,5,3)
#tuple(11,2,3,5)

2.元组常规操作+内置方法

  1)按索引取值(正、反取值,但是不可更改)

t = (11,2,3,5,3)
print(t[2])
print(t[-1])

  2)切片(顾长不顾尾,步长)

# 取第 2-3 个元素
print(t[1:3])

  3)求长度

print(len(t))

  4)成员运算in 和 not in

print(2 in t)

  5)查看索引和计算相同元素的个数

# 查看索引print(t.index(2))

# 计算相同元素的个数print(t.count(3)

总结:

  1.可存多个值

  2.有序

  3.不可变的

二、字典

1.字典基础

  1)用途:以key:value形式存多个值

  2)优点:存储快,每个值都有对应的key

  3)定义方式:}内以逗号隔开多个元素,格式为{key:value....}

  注意:key必须为不可变类型,value可以是任意类型

dic = dict({'name':'zhang','age':18,'x':8,'y':10})
dic = {'name':'zhang','age':18,'x':8,'y':10}
print(dic)

2.字典常规操作+内置方法

  1)按key取值,可存可取

dic = {'name':'zhang','age':18}
dic['name'] = 'zh'
print(dic)

  2)求长度

print(len(dic))

  3)成员运算in 和 not in

print('name' in dic)

  4)pop()

# pop(self,key,default)实现删除,返回删除的元素的value
# 设置default参数时,可在不存在这个key时做出返回,默认返回None
res = dic.pop('name')
res1 = dic.pop('sss','不存在这个key')
print(res)
print(res1)

  5)key()、value()、items()

# key()  查看字典中的键值
print(dic.keys()) # value() 查看字典中value值
print(dic.values()) # items() 查看键对
print(dic.items()) # 循环打印出key,默认打印的就是key
for x in dic.keys():
print(x) # 循环打印出value
for value in dic.values():
print(value) # 循环打印key和value
for i,j in dic.items():
print(i,j)

3.需要掌握的操作

  1)get()

# 根据索引获取value
# 当不存在key返回None
print(dic.get('name'))
print(dic.get('sss'))

  2)popitem()

# 从末尾开始弹出,并返回key和value
print(dic.popitem())

  3)update()

# update() 更新
# 原字典中存在这个key则修改value值,若不存在则添加
print(dic.update({'x':8,'age':20}))
print(dic)

  4)setdefault()

# 字典中有这个key,则不修改,返回原来的key对应的value
# 没有这个key,则添加并返回添加的key的对应的value
res = dic.setdefault('name','ch')
res1 = dic.setdefault('x','hyjk')
print(res)
print(res1)

  5)fromkeys()

# 往空字典中批量添加key,默认vlaue为None
dic_1 = {}
dic_1 = dic_1.fromkeys(['name','age','sex'],None)
print(dic_1)
dic_1['name'] = 'zhang'
print(dic_1)

总结:

  1.可存多个值

  2.无序

  3.可变

练习:

msg_dic={
'apple':10,
'tesla':100000,
'mac':3000,
'lenovo':30000,
'chicken':10,
} for i,j in msg_dic.items():
print(i,j) for key in msg_dic:
print(key,msg_dic[key]) for i in msg_dic.keys():
print(i)
for j in msg_dic.values():
print(j) # 避免key不存在字典中报错,使用get()
print(msg_dic['sss'])
print(msg_dic.get('zhang','输入正确的key')) # 字典操作
set_1 = set({11,22,33,44,55,66,77,88,99,90})
dic_1 = {'k1':[],'K2':[]}
print(set_1)
for i in set_1:
if i > 66:
dic_1['k1'].append(i)
else:
dic_1['K2'].append(i)
print(dic_1) # 统计s='hello alex alex say hello sb sb'
# 中每个单词的个数结果如:
# {'hello': 2, 'alex': 2, 'say': 1, 'sb': 2} s = 'hello alex alex say hello sb sb'
list_s = list(s.split(' '))
dic_s = {}
for i in list_s:
count = list_s.count(i)
dic_s.setdefault(i,count)
print(list_s)
print(dic_s)
三、集合

1.集合基础

  1)定义方式:在{元素1,元素2...}内用逗号分隔开元素

  2)注意问题:集合中没有重复的元素,且无序

          集合的元素必须是不可变类型

  3)用途:关系运算

        去重

# 定义
s = set({1,2,3,4,5,6,4,4,4,4,4'a'})
s = {1,2,3,4,5,6,4,4,4,4,4,'a'}
print(id(s),type(s),s) # 去重
ist_1 = ['a','b','b','c','c','c','s']
print(list(set(list_1)))

  注意:集合中的元素!!!必须是不可变的,但是集合是可变的,因此不能用列表等可变的数据类型作为元素

s = {[1,2,3],'aa'}    # 列表可变,会报错

2.集合常规操作+内置方法实现集合运算

study_linux = {'zhang','alex','egon','李铁','张三'}
study_python = {'李四','zhang','alex','猪','猫','狗'}

  1)交集

print(study_linux & study_python)
print(study_linux.intersection(study_python))

  2)并集

print(study_linux | study_python)
print(study_linux.union(study_python))

  3)差集

print(study_linux - study_python)
print(study_linux.difference(study_python)) print(study_python - study_linux)
print(study_python.difference(study_linux))

  4)交叉补集---两个集合中不相同的元素的集合

print(study_linux ^ study_python)
print(study_linux.symmetric_difference(study_python))

3.需要掌握的操作

study_linux = {'zhang','alex','egon','李铁','张三'}
study_python = {'李四','zhang','alex','猪','猫','狗'}

  1)循环取值

for item in study_linux:
print(item)

  2)求长度

print(len(study_linux))

  3)成员运算in 和 not in

print(len(study_linux))

  4)删除

# discard() 当删除的元素不存在时,不会报错
# 使用remove()时,不存在会报错
study_python.discard('不存在')
print(study_python)
study_linux.discard('zhang')
print(study_linux) # 因为集合是无序的,所以pop()时是随机删除某个元素
study_linux.pop()
print(study_linux)

4.了解知识点

# 父集:爹包含儿子
s1={1,2,3}
s2={1,2}
print(s1.issubset(s2))
print(s2.issubset(s1))
print(s1.issuperset(s2)) # 实现对列表去重,但保留原列表的顺序
list_old = ['a','d','g','a','sjsjsj','d','a']
list_new = []
set_1 = set({}) for item in list_old:
# 当集合中不存在去到的item即list_old的元素时,
# 则添加到集合和新的列表中,如此循环旧的列表
if item not in set_1:
set_1.add(item)
list_new.append(item)
print(list_old)
print(list_new)

总结:

  1.可存多个值

  2.无序

  3.不可变

Python全栈-day5-数据类型的更多相关文章

  1. python全栈 字典数据类型相关知识及操作

    python 全栈开发 一.字典 1. 字典的概念: 字典 : dict 用 {} 来表示,   键位值数据. { key , value }    具有唯一性. 键:都必须是可哈希的     不可变 ...

  2. python全栈 字符串,整数,bool 数据类型运用

    python全栈 一.基本数据类型 1.int: 整数 2.str: 字符串, 一般不存放大量数据. 3.bool: 布尔值,用来判断. True  或者  False 4.list:  列表,用来存 ...

  3. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  4. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

  5. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  6. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

  7. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  8. Python全栈开发【基础一】

    Python全栈开发[第一篇] 本节内容: Python 的种类 Python 的环境 Python 入门(解释器.编码.变量.input输入.if流程控制与缩进.while循环) if流程控制与wh ...

  9. python全栈开发-Day2 布尔、流程控制、循环

    python全栈开发-Day2 布尔 流程控制 循环   一.布尔 1.概述 #布尔值,一个True一个False #计算机俗称电脑,即我们编写程序让计算机运行时,应该是让计算机无限接近人脑,或者说人 ...

  10. python全栈开发中级班全程笔记(第二模块、第四章)(常用模块导入)

    python全栈开发笔记第二模块 第四章 :常用模块(第二部分)     一.os 模块的 详解 1.os.getcwd()    :得到当前工作目录,即当前python解释器所在目录路径 impor ...

随机推荐

  1. Fmod使用总结

    1.查询相关文档的地址 http://www.fmod.org/forum/viewtopic.php?f=7&t=15762

  2. git知识点

    先说几个名词 未被追踪的文件:指的是新建的文件或文件夹且还没加入到暂存区(新建的还没有被git add 过得) 未加入到暂存区的文件:指的是已经被追踪过,但是没有加入到暂存区(已经执行过git add ...

  3. 《mongoDB》索引

    一:基础操作 创建单列索引 语法: >db.collection.createIndex(keys, options) 语法中 Key 值为你要创建的索引字段,1 为指定按升序创建索引,如果你想 ...

  4. 不看好运维竖井产品模式,优云打造融合化运维PaaS平台

    2018年1月13号中国双态运维用户大会上,优云软件总裁刘东海接受了36Kr记者的专访,期间谈到了新时代下的企业运维模式,新兴技术和传统运维的融合以及优云未来的发展方向等问题.以下为访谈实录: 优云软 ...

  5. es的scoll滚动查询技术

    如果一次性要查出来比如10万条数据,那么性能会很差,此时一般会采取用scoll滚动查询,一批一批的查,直到所有数据都查询完处理完 使用scoll滚动搜索,可以先搜索一批数据,然后下次再搜索一批数据,以 ...

  6. 关于eclipse调试时程序控制台不能自动打开

      对于这个程序,在刚开始的时候,没有敲上22,29,33行的打印语句时,在调试的时候不会自动弹开控制台,所以一直在怀疑代码可能出错了.因此可以自己手动打开,但是如果敲上那些代码,系统可以自动弹开控制 ...

  7. 1-4-bootloader架构学习

    1-4-bootloader架构学习 1.一般情况下嵌入式 Linux 系统中的软件主要分为以下几部分: 1) 引导加载程序:其中包括内部 ROM 中的固化启动代码和 BootLoader 两部分. ...

  8. Redis所支持的数据结构

    1.启动Redis2.Redis所支持的数据结构 2.1.Redis常用操作 2.2.String类型及操作 2.3.Hash类型及操作 2.4.List类型及操作 2.5.Set类型及操作 2.6. ...

  9. Linux中程序开机自启

    Linux中程序开机自启 https://www.itbulu.com/debian-ubuntu-rclocal.html

  10. windows(64位)下使用curl安装

    windows(64位)下使用curl安装 转自:https://blog.csdn.net/wkj001/article/details/54889907 2017年02月06日 09:46:47  ...