【Python基础】S01E03 元组

2023-09-20 10:42:59

列表是可修改的,对于处理网站的用户列表或游戏中的角色列表至关重要。然而我们有时候需要创建一系列不可修改的元素,元组可以满足这种需求。Python中,元组是不可修改的列表,名(tuple);

定义元组

元组看起来很像列表,但使用圆括号而非方括号来标识;

元组无法修改

# 访问元组元素
dimensions = (200, 50, 100, 150, 300, 350)
print(dimensions[1])

>>> 50

# 元组无法修改
dimensions = (200, 50, 100, 150, 300, 350)
dimensions[1] = 1000

>>> Traceback (most recent call last):
  File "E:\Code\csdn\test\main.py", line 2, in <module>
    dimensions[1] = 1000
TypeError: 'tuple' object does not support item assignment

定义一个元素的元素

定义一个只包含一个元素的元组;

my_tuple_1 = (3)		# 非元组
my_tuple_2 = (3,)		# 注意一定加逗号
print(type(my_tuple_1))
print(type(my_tuple_2))

>>> <class 'int'>		# my_tuple_1
<class 'tuple'>			# my_tuple_2

修改元组变量

但是如果,我们实在需要修改元组怎么办额?

方案一:关联新元组

既然原元组无法修改,那直接将元组变量名关联到一个新的元组即可;

# 修改 dimensions[1] 为 150:
dimensions = (200, 50, 100)
# 关联到新的元组
dimensions = (200, 150, 100)
print(dimensions)

>>> (200, 150, 100)

方案二:转换为列表

当面临很多的元素时,且只要要替换的位置信息,不妨先转换为列表;

# 修改 dimensions[1] 为 150:
dimensions = (200, 50, 100)
# 转换为列表
dimensions_arr = list(dimensions)
dimensions_arr[1] = 150
print(dimensions_arr)

>>> [200, 150, 100]

当然,也可以从列表转回到元组;

# 接上
dimensions = tuple(dimension_arr)
print(dimensions)

>>> (200, 150, 100)

2023年9月20日
徐鸿铎
北京海淀西三旗

更多推荐

Django系列:Django简介与MTV架构体系概述

Django系列Django简介与MTV架构体系概述作者:李俊才(jcLee95):https://blog.csdn.net/qq_28550263邮箱:291148484@163.com本文地址:https://blog.csdn.net/qq_28550263/article/details/132890054【

本地电脑搭建SFTP服务器,并实现公网访问

本地电脑搭建SFTP服务器,并实现公网访问文章目录本地电脑搭建SFTP服务器,并实现公网访问1.搭建SFTP服务器1.1下载freesshd服务器软件1.3启动SFTP服务1.4添加用户1.5保存所有配置2.安装SFTP客户端FileZilla测试2.1配置一个本地SFTP站点2.2内网连接测试成功3.使用cpolar

react | react-router-dom v6 结合 antd 面包屑 |嵌套路由

大致需求图示如上:需求:1.点击page2默认进入`/page2/中国`2.在中国界面选择省份,进入浙江省3.在浙江省中选择市,进入杭州市4.选择大学,进入浙江大学5.点击面包屑中某个tab,进入对应tab界面,组件/路由切换6.路由携带参数,如面包屑中的数据实现过程:在page2组件内(仅供参考):<divclass

代理IP和Socks5代理:跨界电商与爬虫的智能引擎

跨界电商,作为全球市场的一部分,对数据的需求越来越大。同时,随着互联网的发展,爬虫技术也在不断演进,成为了跨界电商的关键工具之一。然而,随之而来的是网站的反爬虫机制和网络安全风险。在这种情况下,代理IP和Socks5代理应运而生,为企业提供了数据采集的解决方案和网络安全的保护。本文将深入研究代理IP和Socks5代理在

Python爬虫有哪些库,分别怎么用

目录Python常用爬虫库代码示例requests+BeautifulSoupScrapySeleniumPyQueryAxiosrequests-htmlpyppeteer总结Python是一种非常流行的编程语言,因其易学易用和广泛的应用而受到开发者的喜爱。在Python中,有许多库可以用于爬虫程序的开发,这些库可以

第9章 【MySQL】InnoDB的表空间

表空间是一个抽象的概念,对于系统表空间来说,对应着文件系统中一个或多个实际文件;对于每个独立表空间来说,对应着文件系统中一个名为表名.ibd的实际文件。大家可以把表空间想象成被切分为许许多多个页的池子,当我们想为某个表插入一条记录的时候,就从池子中捞出一个对应的页来把数据写进去。9.1温习9.1.1页面类型InnoDB

VINS中的初始化方法

背景本文档介绍VINS中常见的初始化方法,静态初始化相对简单,通常1s内可以完成,但如果遇到在运动时的初始化问题,初始化难度相对较大,实际工程问题中,通常会将初始化分为静态和动态初始化两部分,这里主要是介绍动态初始化方案。一、基础知识:IMUPreintegrationIMUPreintegration等式两边同时乘以

19 视图定义 union 是根据第一个 select 字段列表顺序,来进行 merge 的

前言这个问题主要是在之前存在这样的一个问题,在生产环境上面按照我的直观理解,mysql应该是根据key进行merge,所以select的顺序应该是“不重要”??,但是结果我理解错了然后线上的查询也出现了问题,发现很奇怪的问题,明明key01列是id,但是有一部分key01是field1,然后进而产生了业务上面的查询问题

【多线程案例】单例模式

单例模式是设计模式的一种,先谈谈什么是设计模式?大家应该都知道棋谱、剑谱之类的,就是一些“高手”在经历过长期的累计之后,更具经验写出的具有固定套路的处理“方法”,只要按照这个套路来,在对局之中必然是不会吃亏的,甚至能够一招制敌。那么在我们日常的开发中也有大佬们针对一些十分常见的场景,抽象出固定的套路。一些小白在学习了大

Spark的基础

实训笔记--Spark的基础Spark的基础一、Spark的诞生背景二、Spark概念2.1SparkCore2.2.SparkSQL2.3SparkStreaming2.4SparkMLlib2.5SparkGraphX2.6SparkR三、Spark的特点3.1计算快速3.2易用性3.3兼容性3.4通用性四、Spa

Java IO 之 BIO、NIO 和 AIO

一、IOIO是Input和Output二词的缩写,意为输入和输出,直接来说,实现一般的I/O是没有什么难度的,但涉及到多线程时,要解决I/O的问题就不是一个简单的事情了,会涉及到同步和异步的问题,阻塞和非阻塞的问题。1.1同步和异步同步可以借用多线程来方便理解,多条线程,从字面意思上来看,当他们在同一直线上时,就是同步

热文推荐