Python入门:认识列表和元组
作者:city_water 发布时间:2022-11-06 02:18:42
列表和元组,都是一个可以放置任何数据类型的有序集合。
列表的特性
动态的(mutable):长度大小不固定,可以随意地增加、删减或者改变元素。
会修改原来列表中的元素,而不会创建新的列表。
# 新建一个列表
l = [1, 2, 'hello', 'world']
# 输出列表
l
# 显示内容
[1, 2, 'hello', 'world']
# 访问列表元素
l[3] = 3 # 列表允许访问第4个元素,并修改
# 输出列表
l
# 显示内容
[1, 2, 'hello', 3]
# 添加元素
l.append(5) # 把元素5 添加到列表后面
# 输出列表
l
# 显示内容
[1, 2, 'hello', 3, 5]
元组的特性
静态的(immutable):长度大小固定,无法增加删减或者改变。
若要改变元组内的数据,只能新开一块内存,新建一个元组。
# 新建一个元组
tup = ('jason', 22)
# 输出元组
tup
# 显示内容
('jason', 22)
# 不能对元组直接操作,需要新建一个新元组
net_tup = tup + (5, ) # 创建新的元组new_tup 后,以此填充元素,新增元素后的',' 不可以省略
# 输出元组
net_tup
# 显示内容
('jason', 22, 5)
两者支持的操作
负数索引
列表和元组都支持负数索引,-1 表示倒数第一个元素,-2 表示倒数第二个,以此类推。
l = [1, 2, 'hello', 3, 5]
l[-1] # 列表的负数索引
# 显示内容
5
tup = ('jason', 22)
tup[-1] # 元组的负数索引
# 显示内容
22
切片操作
切片操作指的是,输出规定范围内 [start : end]的所有元素,但不包含最后一位。
例如 [0:3] 就是从下标0 开始,一直输出到下标2(3-1) 。
l = [1, 2, 'hello', 3, 5]
l[0:3] # 列表的切片操作
# 显示内容
[1, 2, 'hello']
tup = ('jason', 22)
tup[0:2] # 元组的切片操作
# 显示内容
('jason', 22)
随意嵌套
new_l = [[1, 2, 3], [4, 5]] # 嵌套列表
new_l
# 显示内容
[[1, 2, 3], [4, 5]]
new_tup = ((1, 2, 3,), (4, 5, 6)) # 嵌套元组
new_tup
# 显示内容
((1, 2, 3), (4, 5, 6))
相互转换
list((1, 2, 3)) # list() 函数把元组转化成列表
tuple([1, 2, 3]) # tuple() 函数把列表转化成元组
常用内置函数
count(item) 统计列表 / 元组中 item 出现的次数
index(item) 返回列表 / 元组中 item 第一次出现的索引
list.reverse() and list.sort() 只能对列表应用
list.reverse() 原地倒转列表
list.sort() 排序
reversed() and sorted()
返回一个倒转后的迭代器,使用list() 将其转换成列表
reversed() 对列表 / 元组进行倒转
sorted() 对列表 / 元组进行排序
返回排好序的新列表
存储方式的差异
l = [1, 2, 3]
l.__sizeof__()
64
tup = (1, 2, 3)
tup.__sizeof__()
48
存储同样的内容,列表却比元组多用了16字节。
列表是动态,需要指针来指向对应的元素。
列表它可变,需要额外存储已经分配的长度大小,追踪列表空间使用的情况,当空间不足时,可以及时分配额外空间。
存储指针的空间长度的存储空间各为8 字节。
列表初始空间是:40,添加字符后会扩展4个元素的空间:32,所以是:72字节。当需要存储的元素空间大于存储空间时,列表会新增4个元素的空间:32。
这样的增加 / 删减操作机制(over-allocating)保证了其操作的有效性,增加 / 删减的时间复杂度均为O(1)
性能对比
元组比列表更加轻量级一些,从总体来讲,元组的性能速度要略优于列表。
Python 会在后台对静态数据做一些资源缓存(resource caching)
垃圾回收机制,当一些变量不被使用了,Python 就会回收它们所占用的内存,返还给操作系统,以便其他变量或其他应用使用。
但元组不被使用并且占用空间不大时,Python 会暂时缓存这一部分。下次调用时,Python 会直接用这块缓存的内存空间,大大加快程序的运行速度。
初始化一个相同元素的列表和元组,元组的速度比列表快5倍。
索引操作,两者速度差别非常小,几乎可以忽略不计。
增加 / 删减或改变元素,列表更优。元组需要新建一个元组。
两者的使用场景
存储的数据和数量不变,选用元组合适。存储的数据或数量是可变的,选择列表更合适。
来源:https://blog.csdn.net/weixin_43776724/article/details/120856567


猜你喜欢
- 实际中,很多数据都是存为txt文件、csv文件等,但是在程序中处理的时候numpy数组或列表是最方便的。本文简单介绍读入txt文件以及将之转
- 方法一:在目前绝大部分数据库有分布式查询的需要。下面简单的介绍如何在oracle中配置实现跨库访问。比如现在有2个数据库服务器,安装了2个数
- 维护脚本一例,写得有点乱,只是作为一个实例,演示如何快速利用工具快速达到目的:应用到:shell与python数据交互、数据抓取,编码转换#
- 如下所示:import pymysqlimport timeimport redef get_raw_label(rece): re1 =
- 最近发现一常见的加载进度条(loadding)的问题,所以试试,觉得还不错,大家可以看下.当然这个只是一个效果而已!呵呵,用的着的时候,你就
- 1. watch 与 computed 的巧妙结合如上图,一个简单的列表页面。你可能会这么做: created(){ this.
- 1. linux下消息记录关于系统的各种消息一般都会记录在/var/log/messages文件中,有些主机在中默认情况下有可能没有启用,具
- 这里再重复一下标题为什么是"使用"而不是"实现":首先,专业人士提供的算法比我们自己写的算法无论是效
- 本文分为两个部分,第一部分是关于pip,第二部分关于pygal,主要关于二者的简介以及安装过程的分享,希望对大家有所帮助。一、pip1.简介
- 这里想象一下需求,写一个项目使用的一系列1.0版本的插件,现在要新写一个项目,需要用这些插件的2.0版本,该怎么办?都更新成2.0版本?这样
- 本文实例讲述了Python自动扫雷实现方法。分享给大家供大家参考。具体如下:#pyWinmineCrack.py# coding: utf-
- 项目中要对短文本进行相似度估计,word2vec是一个很火的工具。本文就word2vec的训练以及加载进行了总结。word2vec的原理就不
- 在上篇博客中,我们已经实现了水平投影和垂直投影图的绘制。接下来,我们可以根据获得的投影数据进行图像的分割,该法用于文本分割较多,所以此处依然
- 如何让我的网页自动适应客户端的屏幕分辨率?然后用下列办法进行自动推送:<% @language="vbscript
- 一、lambda关键字的使用方法func=lambda x:x+1print(func(1))#2print(func(2))#3#以上la
- 数据添加函数实例//数据添加 public function newData($strName="") &n
- 一: 删除LOG1:分离数据库 企业管理器->服务器->数据库->右键->分离数据库2:删除LOG文件3:附加数据库 企业管理器->服务器-
- 1 端口映射举个例子来说明一下端口映射的作用。有A、B、C三台计算机,A、B互通,B、C互通,但是A、C不通,这个时候在C上开了一个Web服
- 思路改进原博主文章(Python GUI–Tkinter简单实现个性签名设计)的代码,原先的代码是基于Python2的,我这份代码基于Pyt
- 一、数学函数ABS(x) 返回x的绝对值BIN(x) 返回x的二进制(OCT返回八进制,HE