Python笔记_第一篇_面向过程_第一部分_5.Python数据类型之元组类型(tuple)
元组!在Python中元组是属于列表的一种延伸,也是一种有序集合,成为一种只读列表,即数据可以被查找,不能被修改,列表的切片操作同样适用于元组。
特点:1. 与列表非常相似。
2. 一旦初始化就不能修改(这句话的意思是:元素不可变,但是元素中的值可以改)。
3. 使用小括号。
4. 如果元素当中只有一个元素(12, ),书写习惯上也应该加上一个逗号。原因和列表这个地方的原因是一样的。
1. 元组的简单应用
1.1 创建元组
格式:元组名 = (元组选项1,元组选项2,元组选项n)
创建一个空元组和带有元素的元组。
# 创建空的元组
tuple1 = ()
print(tuple1)
# 输出结果:() # 创建带有元素的元组
# 元组中的元素的类型可以不同
tuple2 = (1, 2, 3, "good", True)
print(tuple2)
# 输出结果:(1, 2, 3, 'good', True) # 定义只有一个元素的元祖
tuple3 = (1, )
print(tuple3)
print(type(tuple3))
# 输出结果:
# (1,)
# <class 'tuple'>
1.2 元组的常规操作
1.2.1 元素元素的访问
# 元组元素的访问
# 格式:元组名[下标]
tuple4 = (1, 2, 3, 4, 5)
print(tuple4[0])
# print(tuple4[5]) # 下标越界报错
print(tuple4[-1]) # 获取最后一个元素
# 输出结果:
#
#
1.2.2 元组元素的修改
元组不允许修改元素,但是元组当中元素的值(二级目录一下的值可以修改)
# 修改元组
tuple5 = (1, 2, 3, 4, [5, 6, 7])
tuple5[-1][0] = 500 # 改变里面的list可以变
print(tuple5)
# 输出结果:(1, 2, 3, 4, [500, 6, 7]) # 元组的元素不能修改
tuple6 = (1, 2, 3, "good", True)
tuple6[3] = "bad" # 改变里面的list可以变
print(tuple6)
# 输出结果:
# Traceback (most recent call last):
# File "C:/Users/Administrator/Desktop/Python-1704/day04/tuple(元组).py", line 51, in <module>
# tuple6[3] = "bad" # 改变里面的list可以变
# TypeError: 'tuple' object does not support item assignment
1.2.3 元组元素的删除
# 删除元组
tuple6 = (1, 2, 3)
del tuple6[0]
del tuple6
print(tuple6)
# 输出结果:
# 不允许删除元组的元素
# Traceback (most recent call last):
# File "C:/Users/Administrator/Desktop/Python-1704/day04/tuple(元组).py", line 67, in <module>
# del tuple6[0]
# TypeError: 'tuple' object doesn't support item deletion
# 删除整个元组
# Traceback (most recent call last):
# File "C:/Users/Administrator/Desktop/Python-1704/day04/tuple(元组).py", line 69, in <module>
# print(tuple6)
# NameError: name 'tuple6' is not defined
1.2.4 元组的组合
# 元组的组合
t7 = (1, 2, 3)
t8 = (4, 5, 6)
t9 = t7 + t8
print(t7 + t8)
print(t7, t8)
print(t9)
# 输出结果:
# (1, 2, 3, 4, 5, 6)
# (1, 2, 3) (4, 5, 6)
# (1, 2, 3, 4, 5, 6)
1.2.5 元组的重复
# 元组重复
t10 = (1, 2, 3)
print(t10 * 3)
# 输出结果:(1, 2, 3, 1, 2, 3, 1, 2, 3)
1.2.6 判断元素是否在元组中,返回值为False 或 True,成员运算符(in,not in);身份运算符同理不再举例。
# 判断元素是否在元组中
t11 = (1, 2, 3)
print(1 in t11)
# 输出结果:True
1.2.7 元组的截取(切片)
格式:[[start] [,end] [,step]],开始位置,结束位置,步长
注意:几到几的指针是放到元素的前面。
# 元组的截取
# 格式:元组名[开始下标,结束下标]
# 从开始下标开始截取,截取到结束下标之前
t12 = (1, 2, 3, 4, 5, 6, 7, 8, 9)
print(t12[3:7])
print(t12[3:])
print(t12[:7])
# 输出结果:
# (4, 5, 6, 7)
# (4, 5, 6, 7, 8, 9)
# (1, 2, 3, 4, 5, 6, 7)
1.2.8 二维元组和三维元组
二维元组和三维元组,以及其他高维元组的逻辑是在元组内在表示一组元组元素。访问也是通过双下标、三下标或高下标的方式访问,操作高维元组和操作一维元组的逻辑是一样的。
# 二位元组,及其以上元组,元素为一维元组的元组
t13 = ((1, 2, 3), (4, 5, 6), (7, 8, 9))
print(t13[1][1])
# 输出结果:访问第二个元组中的第二个元素
#
2. 元组的常见内建函数的应用
函:len
语:len(tuple)
用:返回元组中元素的个数
# 元组的方法
# len 返回元组中元素的个数
t14 = (1, 2, 3, 4, 5)
print(len(t14))
# 输出结果:
#
函:max()、min()
语:max(tuple)、min(tuple)
用:返回元组中的最大值、返回元组中的最小值
# max()返回元组中的最大值
# min()返回元组中的最小值
print(max((5, 6, 7, 8, 9)))
print(min((5, 6, 7, 8, 9)))
# 输出结果:9 5
3. 元组常用技巧
3.1 将列表转换为元组
# 将列表转为元组
list = [1, 2, 3]
t15 = tuple(list)
print(t15)
print(type(t15))
# 输出结果:
# (1, 2, 3)
# <class 'tuple'>
3.2 元组的遍历
函:enumerate
语:enumerate(e, start = )
用:枚举函数,start= 表示从数字几开始记录枚举的起始,如果是0,就为0,1,2,3,4......为序号开始标记;如果为1,就为1,2,3,4,5,为序号开始标记;默认为从0开始。
# 元组的历编
for i in (1, 2, 3, 4, 5):
print(i, end="")
print("\n")
# 输出结果:12345 # 通过枚举的方式遍历元组元素
for i, v in enumerate((1, 2, 3, 4, 5), 1):
print(i, v)
# 输出结果:
# 1 1
# 2 2
# 3 3
# 4 4
# 5 5
Python笔记_第一篇_面向过程_第一部分_5.Python数据类型之元组类型(tuple)的更多相关文章
- Python笔记_第一篇_面向过程_第一部分_2.内存详解
Python的很多教材中并没有讲内存方面的知识,但是内存的知识非常重要,对于计算机工作原理和方便理解编程语言是非常重要的,尤其是小白,因此需要把这一方面加上,能够更加深入的理解编程语言.这里引用了C语 ...
- Python笔记_第一篇_面向过程_第一部分_1.Python环境的设置(含虚拟机)
*Python环境的设置 Python的环境设置也就是所需工作平台的软件搭建.常用的搭建平台IOS系统+Linux系统和Windows+Linux系统的搭建.这里主要说明的是Windows+Linux ...
- Python笔记_第一篇_面向过程_第一部分_6.条件控制语句(if)
Python正如其他语言一样存在两种常用的逻辑判断体(也叫结构化程序设计).所谓逻辑判断体是通过你想要完成的编程思路,通过在逻辑判断体中的相互判断和作用得到你想要的结果.逻辑判断体也叫控制语句,Pyt ...
- Python笔记_第二篇_面向过程_第二部分_2.路径、栈和队列、内存修改
这一部分分三个主题进行讲解,主要为后面的模块.包.第三方库的概念补充一些相关的内容. 1. 路径(Path): 相对路径和绝对路径. 举例1:我们先导入一个os库(模块)来观察一下路径 import ...
- 四、java基础-面向过程_对象_类中可出现的因素
1.面向过程和面向对象区别: 1)面向过程:开发一个应用程序.一个项目,必须先了解整个过程,了解各个步骤.模块间的因果关系,使的面向过程方式去开发程序时,代码和代码之间的关联程度是非常强.所以其中任何 ...
- python自动化开发-[第五天]-面向过程、模块、包
今日概要: 1.内置模块 2.协程函数 3.递归 4.面向过程编程与函数编程 5.模块 6.包 7.re正则 一.内置模块 1.匿名函数lambda 定义:匿名函数通常是创建了可以被调用的函数,它返回 ...
- python第四周迭代器生成器序列化面向过程递归
第一节装饰器复习和知识储备------------ 第一节装饰器复习和知识储备------------ def wrapper(*args,**kwargs): index(*args,**kwa ...
- [Python笔记]第八篇:模块
本篇主要内容:python常用模块用法介绍 什么是模块 模块,用一大段代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性 ...
- [Python笔记]第三篇:深浅拷贝、函数
本篇主要内容:深浅拷贝,自定义函数,三目运算,lambda表达式, 深浅拷贝 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. import ...
随机推荐
- 使用Oracle VM VirtualBox安装CentOS 7.6操作系统
使用Oracle VM VirtualBox安装CentOS 7.6操作系统 ...
- HDU - 6025 Coprime Sequence(前缀gcd+后缀gcd)
题意:去除数列中的一个数字,使去除后数列中所有数字的gcd尽可能大. 分析:这个题所谓的Coprime Sequence,就是个例子而已嘛,题目中没有任何语句说明给定的数列所有数字gcd一定为1→_→ ...
- 线程与进程 queue模块
queue模块的基本用法 https://www.cnblogs.com/chengd/articles/7778506.html 模块实现了3种类型的队列,区别在于队列中条目检索的顺序不同.在FIF ...
- qt 字符串 转换 hex
1. qt 中两个字符的字符串直接转换为 hex,类似于 "1A" 要转换成 16进制的 0x1A,使用 int QString::toInt(bool *ok, int base ...
- MySQL-半同步复制原理实践
参考文档: http://mysql.taobao.org/monthly/2017/04/01/ 阿里内核月报半同步复制的数据一致性 https://www.cnblogs.com/ivictor/ ...
- C#构造函数调用其他构造函数
http://blog.csdn.net/dogfish/article/details/6990266 <-- 虏来的地 public class Class1 { public Class ...
- 提升Python编程效率的几种方法
前言 我们知道Python这门语言在运行速度上已经败给了许多别的语言(比如C, C++, Java, Golang....).但从一个开发者的角度来看Python是我最喜欢的语言,很大一部分原因在于其 ...
- 日志处理中一些shell命令技巧
日志处理中一些shell命令技巧 阴差阳错的做的日志分析,前途未卜的这段日子,唯一还有点意思的可能就是手动的处理大量日志.总结一下. 日志文件的输入是动则几个G的文本.从N个这样的文件中得到一个列表, ...
- PAT Advanced 1079 Total Sales of Supply Chain (25) [DFS,BFS,树的遍历]
题目 A supply chain is a network of retailers(零售商), distributors(经销商), and suppliers(供应商)– everyone in ...
- 寒假day15
今天完成了毕设的人才动态模块,同时刷了计算机网络的相关面试题