百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Python列表详解 python列表的常用方法

liuian 2024-12-28 14:12 27 浏览

一、创建列表

从形式上看,列表会将所有元素都放在一对中括号[ ]里面,相邻元素之间用逗号,分隔,如下所示:

[element1, element2, element3, ..., elementn]

在 Python 中,创建列表的方法可分为两种:

1.使用 [ ] 直接创建列表

使用[ ]创建列表后,一般使用=将它赋值给某个变量,具体格式如下:

listname = [element1 , element2 , element3 , ... , elementn]

其中,listname 表示变量名,element1 ~ elementn 表示列表元素。

# 使用[]创建列表
list_number = [1, 2, 3, 4, 5, 6, 7, 8, 9]
list_str = ["lucy", "kitty", "nick"]

2.使用 list() 函数创建列表

除了使用[ ]创建列表外,Python 还提供了一个内置的函数 list(),使用它可以将其它数据类型转换为列表类型。

# 使用list()函数将其他数据类型转换为列表
# 转换字符串
name = "hello"
list_name = list(name)
print(list_name)  # ['h', 'e', 'l', 'l', 'o']
# 转换元组
tuple1 = ("age", "name", "height", "weight")
list_tu = list(tuple1)
print(list_tu)  # ['age', 'name', 'height', 'weight']
# 转换字典
dict1 = {"name": "chen", "age": 28, "height": "175cm", "weight": "75kg"}
list_dic = list(dict1)
print(list_dic)  # ['name', 'age', 'height', 'weight']

二、访问列表元素

列表是 Python 序列的一种,我们可以使用索引(Index)访问列表中的某个元素(得到的是一个元素的值),也可以使用切片访问列表中的一组元素(得到的是一个新的子列表)。

◆ 使用索引访问列表元素的格式为:listname[i]

其中,listname 表示列表名字,i 表示索引值。列表的索引可以是正数,也可以是负数。

◆ 使用切片访问列表元素的格式为:listname[start : end : step]

其中,listname 表示列表名字,start 表示起始索引,end 表示结束索引,step 表示步长。

◆ 获取列表所有元素:listname[:]

# 访问列表元素
list_number = [1, 2, 3, 4, 5, 6, 7, 8, 9]
print(list_number[0])  # 列表第一个元素,1
print(list_number[-1])  # 列表最后一个元素,9
print(list_number[0:5])  # 列表切片,[1, 2, 3, 4, 5]
print(list_number[0:-1:2])  # 列表切片、并指定步长,[1, 3, 5, 7]
print(list_number[-5:-1:1])  # 使用负数切片、并指定步长,[5, 6, 7, 8]
print(list_number[:])  # 获取列表所有元素,[1, 2, 3, 4, 5, 6, 7, 8, 9]

三、列表添加元素

实际开发中,经常需要对 Python 列表进行更新,包括向列表中添加元素、修改表中元素以及删除元素。一共有3种方法:

1.append()方法添加元素

append() 方法用于在列表的末尾追加元素,该方法的语法格式如下:listname.append(obj)

其中,listname 表示要添加元素的列表;obj 表示到添加到列表末尾的数据,它可以是单个元素,也可以是列表、元组等。

# 列表添加元素
list_app = [1, 2, 3]
# 添加元素-append
list_app.append(4)  # 在末尾添加
print(list_app)  # [1, 2, 3, 4]

2.extend()方法添加元素

extend() 方法的语法格式如下:listname.extend(obj)

其中,listname 指的是要添加元素的列表;obj 表示到添加到列表末尾的数据,它可以是单个元素,也可以是列表、元组等。

# 列表添加元素
list_app = [1, 2, 3]
# 添加元素-extend
a = ['a', 'b', 'c']
list_app.extend(a)  # 列表添加列表,在末尾添加
print(list_app)  # [1, 2, 3, 4, 'a', 'b', 'c']
b = (110, 120, 119)
list_app.extend(b)  # 列表添加元组,在末尾添加
print(list_app)  # [1, 2, 3, 4, 'a', 'b', 'c', 110, 120, 119]

3.insert()方法插入元素

insert() 的语法格式如下:listname.insert(index , obj)

其中,index 表示指定位置的索引值。insert() 会将 obj 插入到 listname 列表第 index 个元素的位置。

# 列表添加元素
list_app = [1, 2, 3]
# 添加元素-insert
list_app.insert(0, 555)  # 在指定位置添加元素
print(list_app)  # [555, 1, 2, 3, 4, 'a', 'b', 'c', 110, 120, 119]

四、列表删除元素

在 Python 列表中删除元素主要分为以下 3 种场景:

  • 根据目标元素所在位置的索引进行删除,可以使用 del 关键字或者 pop() 方法;
  • 根据元素本身的值进行删除,可使用列表(list类型)提供的 remove() 方法;
  • 将列表中所有元素全部删除,可使用列表(list类型)提供的 clear() 方法。

1.del:根据索引值删除元素

  • del 可以删除列表中的单个元素,格式为:del listname[index]
  • del 也可以删除中间一段连续的元素,格式为:del listname[start : end]
# 列表删除元素
list_del = [1, 2, 3, 4, 5, 6, 7, 8, 9]
# del-根据索引值删除元素
del list_del[0]  # 在指定位置添加元素
print(list_del)  # [2, 3, 4, 5, 6, 7, 8, 9]

2.pop():根据索引值删除元素

Python pop() 方法用来删除列表中指定索引处的元素,具体格式如下:listname.pop(index)

# 列表删除元素
list_del = [1, 2, 3, 4, 5, 6, 7, 8, 9]

# pop-根据索引值删除元素
list_del.pop()  # 不添加索引,默认删除最后一个元素
print(list_del)  # [2, 3, 4, 5, 6, 7, 8]
list_del.pop(0)  # 添加索引,删除指定索引的元素
print(list_del)  # [3, 4, 5, 6, 7, 8]

3.remove():根据元素值进行删除

除了 del 关键字,Python 还提供了 remove() 方法,该方法会根据元素本身的值来进行删除操作。 删除不存在的元素时,会报错。

# 列表删除元素
list_del = [1, 2, 3, 4, 5, 6, 7, 8, 9]

# remove-根据元素值进行删除
list_del.remove(6)
print(list_del)  # [3, 4, 5, 7, 8]

4.clear():删除列表所有元素

Python clear() 用来删除列表的所有元素,即清空列表。

# 列表删除元素
list_del = [1, 2, 3, 4, 5, 6, 7, 8, 9]

# clear-删除列表所有元素(清空列表)
list_del.clear()
print(list_del)  # []

五、列表查找元素

Python 列表(list)提供了 index() 和 count() 方法,可以用来查找元素。

1.index() 方法

index() 方法用来查找某个元素在列表中出现的位置(也就是索引),如果该元素不存在,则会导致 ValueError 错误,所以在查找之前最好使用 count() 方法判断一下。

index() 的语法格式为:listname.index(obj, start, end)

其中,listname 表示列表名称,obj 表示要查找的元素,start 表示起始位置,end 表示结束位置。

start 和 end 参数用来指定检索范围:

  • start 和 end 可以都不写,此时会检索整个列表;
  • 如果只写 start 不写 end,那么表示检索从 start 到末尾的元素;
  • 如果 start 和 end 都写,那么表示检索 start 和 end 之间的元素。

2.count()方法

count() 方法用来统计某个元素在列表中出现的次数,基本语法格式为:listname.count(obj)

其中,listname 代表列表名,obj 表示要统计的元素。如果 count() 返回 0,就表示列表中不存在该元素,所以 count() 也可以用来判断列表中的某个元素是否存在。

# 列表元素出现次数统计
list_cou = ["c", "c++", "java", "python", "python", ".net", "c#", "go", "js", "java", "object-c", "python"]
print(list_cou.count("python"))  # 返回3
if list_cou.count("java"):  # 判断元素是否存在列表中,存在会返回1,即True,故可以用来做判断
    print("java存在于列表list_cou中")
else:
    print("列表list_cou中不存在java元素")

六、列表反转、排序

1.reverse

列表元素反转,用法:listname.reverse()

# reverse-列表元素反转,不改变ID
list_rev = [5, 6, 7, 1, 2, 3, 4]
list_rev.reverse()
print(list_rev)  # [4, 3, 2, 1, 7, 6, 5]

2.sort

列表排序,覆盖原列表,不改变ID,用法:listname.sort()

# sort-列表排序,覆盖原列表,不改变ID
list_sor = [5, 6, 7, 1, 2, 3, 4]
print(id(list_sor))  # 48733864
list_sor.sort()
print(list_sor)  # [1, 2, 3, 4, 5, 6, 7]
print(id(list_sor))  # 48733864

3.sorted

列表排序,生成新列表,用法:sorted(listname)

# sorted-列表排序,生成新列表
list_std = [8, 5, 6, 9, 4, 1]
print(id(list_std))  # 原ID:60944456
list_std_new = sorted(list_std)
print(list_std_new)  # [1, 4, 5, 6, 8, 9]
print(id(list_std_new))  # 生成的新列表的ID:60944520

总结

1.创建列表:

  • []
  • list()函数

2.访问列表元素:

  • 使用索引访问列表元素的格式为:listname[i]
  • 使用切片访问列表元素的格式为:listname[start : end : step]
  • 获取列表所有元素:listname[:]

3.列表添加元素:

  • append:末尾追加元素
  • extend:末尾添加元素,可以是单个元素、列表、元组
  • insert:列表指定位置添加元素

4.列表删除元素:

  • del:根据索引值删除元素,可以是单个元素,也可以是一段元素
  • pop:删除指定索引位置的元素
  • remove:根据元素值进行删除
  • clear:删除列表所有元素(清空列表)

5.列表查找元素:

  • count:统计某个元素在列表中出现的次数,也可以判断元素是否存在
  • index:查找某个元素在列表中出现的位置

6.列表反转&排序:

  • reverse:列表元素反转
  • sort:列表排序,不生成新列表
  • sorted:列表排序,生成新列表

相关推荐

GANs为何引爆机器学习?这篇基于TensorFlow的实例教程为你解惑!

「机器人圈导览」:生成对抗网络无疑是机器学习领域近三年来最火爆的研究领域,相关论文层出不求,各种领域的应用层出不穷。那么,GAN到底如何实践?本文编译自Medium,该文作者以一朵玫瑰花为例,详细阐...

高丽大学等机构联合发布StarGAN:可自定义表情和面部特征

原文来源:arXiv、GitHub作者:YunjeyChoi、MinjeChoi、MunyoungKim、Jung-WooHa、SungKim、JaegulChoo「雷克世界」编译:嗯~...

TensorFlow和PyTorch相继发布最新版,有何变化

原文来源:GitHub「机器人圈」编译:嗯~阿童木呀、多啦A亮Tensorflow主要特征和改进在Tensorflow库中添加封装评估量。所添加的评估量列表如下:1.深度神经网络分类器(DNNCl...

「2022 年」崔庆才 Python3 爬虫教程 - 深度学习识别滑动验证码缺口

上一节我们使用OpenCV识别了图形验证码躯壳欧。这时候就有朋友可能会说了,现在深度学习不是对图像识别很准吗?那深度学习可以用在识别滑动验证码缺口位置吗?当然也是可以的,本节我们就来了解下使用深度...

20K star!搞定 LLM 微调的开源利器

LLM(大语言模型)微调一直都是老大难问题,不仅因为微调需要大量的计算资源,而且微调的方法也很多,要去尝试每种方法的效果,需要安装大量的第三方库和依赖,甚至要接入一些框架,可能在还没开始微调就已经因为...

大模型DeepSeek本地部署后如何进行自定义调整?

1.理解模型架构a)查看深度求索官方文档或提供的源代码文件,了解模型的结构、输入输出格式以及支持的功能。模型是否为预训练权重?如果是,可以在预训练的基础上进行微调(Fine-tuning)。是否需要...

因配置不当,约5000个AI模型与数据集在公网暴露

除了可访问机器学习模型外,暴露的数据还可能包括训练数据集、超参数,甚至是用于构建模型的原始数据。前情回顾·人工智能安全动态向ChatGPT植入恶意“长期记忆”,持续窃取用户输入数据多模态大语言模型的致...

基于pytorch的深度学习人员重识别

基于pytorch的深度学习人员重识别Torchreid是一个库。基于pytorch的深度学习人员重识别。特点:支持多GPU训练支持图像的人员重识别与视频的人员重识别端到端的训练与评估简单的re...

DeepSeek本地部署:轻松训练你的AI模型

引言:为什么选择本地部署?在AI技术飞速发展的今天,越来越多的企业和个人希望将AI技术应用于实际场景中。然而,对于一些对数据隐私和计算资源有特殊需求的用户来说,云端部署可能并不是最佳选择。此时,本地部...

谷歌今天又开源了,这次是Sketch-RNN

前不久,谷歌公布了一项最新技术,可以教机器画画。今天,谷歌开源了代码。在我们研究其代码之前,首先先按要求设置Magenta环境。(https://github.com/tensorflow/magen...

Tensorflow 使用预训练模型训练的完整流程

前面已经介绍了深度学习框架Tensorflow的图像的标注和训练数据的准备工作,本文介绍一下使用预训练模型完成训练并导出训练的模型。1.选择预训练模型1.1下载预训练模型首先需要在Tensorf...

30天大模型调优学习计划(30分钟训练大模型)

30天大模型调优学习计划,结合Unsloth和Lora进行大模型微调,掌握大模型基础知识和调优方法,熟练应用。第1周:基础入门目标:了解大模型基础并熟悉Unsloth等工具的基本使用。Day1:大模...

python爬取喜马拉雅音频,json参数解析

一.抓包分析json,获取加密方式1.抓包获取音频界面f12打开抓包工具,播放一个(非vip)视频,点击“媒体”单击打开可以复制URL,发现就是我们要的音频。复制“CKwRIJEEXn-cABa0Tg...

五、JSONPath使用(Python)(json数据python)

1.安装方法pipinstalljsonpath2.jsonpath与Xpath下面表格是jsonpath语法与Xpath的完整概述和比较。Xpathjsonpath概述/$根节点.@当前节点...

Python网络爬虫的时候json=就是让你少写个json.dumps()

大家好,我是皮皮。一、前言前几天在Python白银交流群【空翼】问了一个Python网络爬虫的问题,提问截图如下:登录请求地址是这个:二、实现过程这里【甯同学】给了一个提示,如下所示:估计很多小伙伴和...