Python编程基础:列表的正确使用

简介: Python基础语法——列表的正确使用,巩固现有的Python基础知识。

一、前言

前面我们学习了Python中字符串的正确使用,希望大家从中学习到了知识,今天我们再来了解一下Python中有关列表的正确使用,列表的使用的频率也是非常的高,正确灵活的使用将是基础。

学习列表的使用之前,先来了解一下列表是什么。

列表是由一系列按特定顺序排列的元素组成,列表内的元素可以是任何类型,而且允许重复,并且列表属于可变数据类型,允许直接对列表对象进行增删改查操作。

在Python中,用方括号[]表示列表,在其中并用逗号分隔其中的元素,如:

ls= ['Python', 'Java', 'C/C++']

这就是一个简单列表,好啦,了解完列表的特性以及表示方法,接下来我们就开始学习如何正确的使用列表吧。

二、我的环境

  • 电脑系统:Windows 11
  • 语言版本:Python 3.10.4
  • 编译器:VSCode

三、列表的创建

列表的创建有两种方法:

  • 使用[]创建
empty1= []     //创建空列表ls1= [1, 'word', {'like': 'python'}, True, [1, 2]]
  • 使用list()函数创建,可以把其他非列表类型的对象转换为列表类型
empty2=list()     //创建空列表ls2=list("student")   //创建['s', 't', 'u', 'd', 'e', 'n', 't']列表

四、访问列表元素

因为列表是有序集合,所以访问列表中的任意元素只需将该元素的位置即索引就可以访问到该元素,另外,在Python中列表中的索引从0开始而不是从1开始,我们可以从左到右访问索引,也可以从右往左访问索引。

例如:

ls1= [1, 'word', {'like': 'python'}, True, [1, 2]]
print(ls1[0])
print(ls1[-1])

它运行的结果是:

1[1, 2]

需要注意的是,当你访问索引的时候不能超过列表本身的长度即索引越界,如果越界就会报错。当列表很长你不清楚列表的总长度时,你可以使用len()函数打印列表的长度,这样列表的最后一个值的索引即是len(list)-1

我们也可以根据列表的内容查找内容的索引位置,使用index()函数即可返回指定内容的索引值。

ls1= [1, 'word', {'like': 'python'}, True, [1, 2]]
print(ls1.index('word'))

它运行的结果是:

1

有时候你想知道一个很长的列表有没有你想查询的那个内容时,为了避免因查询不到你指定内容而报错,我们可以使用in操作来先判断该内容是否在这个列表中。

ls1= [1, 'word', {'like': 'python'}, True, [1, 2]]
print(ls1.index(False)) ifFalseinls1elseprint("False not in!")

它输出的结果是:

Falsenotin!

五、列表切片

列表切片的作用就是去列表中0到多个元素,形成子列表,需要注意的是,切片不会改变原始列表,而是会产生一个系的列表对象,这与Numpy中的数组切片不同,后者得到的原数组对象的一个视图,修改切片中的内容会导致修改原来的数组对象。

列表切片语法格式如下:

sequence_name[start:end:step]   //start起始索引,end终止索引,step步长

注意取元素规则是左闭右开区间,不包括end,当step为1时,提取元素个数为(end-start)

举几个例子:

ls1= [1, 'word', {'like': 'python'}, True, [1, 2]]
ls1[2:4]        //提取索引为2和3的两个元素ls1[2:]         //提取从索引2开始的全部后面元素,包含最后一个元素ls1[2:-1]       //提取从索引2开始的后面元素,但不包含最后一个元素ls1[:]          //提取所有元素ls1[::-1]       //逆序整个列表

step为正时,表示提取的方向时从左到右,正常情况是要求start小于end,如果start大于或等于end,则切片操作按提取方向无法到达end,将会返回空列表。

step为负时,表示提取方向是从右到左,正常情况是要求start大于end,如果start小于或等于end,则切片操作按提取方向无法到达end,也会返回空列表。

六、列表元素的增删改查

1、列表的增加

使用append()方法在列表末尾添加元素。

fruit= [1, 'word', True, 'pear']
month= ['January', 'February']
fruit.append(month)     //[1, 'word',  True, 'pear', ['January', 'February']]

使用extend()方法也是在列表末尾添加元素。

fruit.extend(month)     //[1, 'word', True, 'pear', 'January', 'February']

使用insert()方法在指定索引位置插入新元素。

fruit.insert(-1, 'apple')       //[1, 'word', True, 'apple', 'pear']

其中append方法是作为一个元素追加到当前列表尾部,extend方法是作为一个序列对象与当前列表对象合并,insert方法是作为一个元素插入到当前列表的指定位置。

2、列表的删除

使用del()函数删除:

delfruit[0:2]

使用del删除时,我们得不到被删除的元素,并且如果要删除整个列表对象则要使用del fruit,因此del既可以按索引删除,也可以按切片删除,还可以删除整个对象。

使用pop()方法删除:

temp=fruit.pop(2)

pop删除能返回被删除的元素,并且当下表没有确定的话,会默认删除列表的最后一个元素。

使用remove()方法删除:

fruit.remove('pear')

当列表中数据重复时,只删除下标值最小的元素。

我们还可以使用clear()方法清空整个列表,让它成为一个空列表,但不能删除列表对象。

fruit.clear()

3、列表的修改

列表单个元素的修改:

fruit[0] ='orange'

列表一段元素的修改:

fruit[0:1] ='Hello', 'world'

4、列表的查找

fruit[3]        //按索引查找元素fruit.index('pear')     //按元素查找索引fruit.count('word')     //统计该元素在列表中出现的次数七、组织列表

在创建列表的时候,元素的排列顺序时无法预测的,有时候,我们希望保留列表元素最初的排列顺序,而有时候又需要调整排列顺序,Python为我们提供了两个方法方便我们去按实际情况灵活的应用。

1、使用方法sort()对列表永久排序

languages= ['Python', 'Java', 'C/C++', 'Go']
languages.sort()
print(languages)

它运行的结果是:

['C/C++', 'Go', 'Java', 'Python']

现在它们是按照字母顺序排列的,且再也无法恢复到原来的排列顺序了。

我们还可以按与字母顺序相反的顺序排列列表元素,只需向sort()方法中传入参数reverse=True即可。

languages= ['Python', 'Java', 'C/C++', 'Go']
languages.sort(reverse=True)
print(languages)

它运行的结果是:

['Python', 'Java', 'Go', 'C/C++']

2、使用函数sorted()对列表临时排序

要保留列表元素原来的排列顺序,同时以特定的顺序呈现它们,可以使用函数sorted()来实现。

languages= ['Python', 'Java', 'C/C++', 'Go']
print(sorted(languages))
print(languages)

它运行的结果是:

['C/C++', 'Go', 'Java', 'Python']
['Python', 'Java', 'C/C++', 'Go']

可以看出它并没有修改原本列表的顺序,该函数参数也可以传入参数reverse=True来实现按与字母顺序相反的顺序显示列表。

八、列表推导式

Python推导式允许以简洁的方式从一个可迭代对象构建出一个新的数据结构,共有三种推导式:列表推导式、字典推导式和集合推导式。

其中列表推导式的基本语法是:

(1)不带条件的列表推导式

[表达式for变量in可迭代对象]  

(2)带条件的列表推导式

  • 单分支:

[表达式for变量in可迭代对象if条件]

  • 双分支

[表达式1if条件else表达式2for变量in可迭代对象]

(3)列表推导式的嵌套使用:

[for变量1in可迭代对象1if条件1for变量2in可迭代对象2if条件2]

列表推导式有助于简化for循环的写法,推荐熟练使用这些方法,可以让我们的代码更加的简洁。

九、最后我想说

本期的Python列表学习就到这里结束了,后续应该就会更新有关Python元组的使用,然后再就是函数等等,慢慢来复习巩固基础知识。

如果你是刚刚入门的新手,欢迎和我一起来学习Python的基础知识,如果你是大佬也可以浏览一遍回顾一下基础知识。

本身Python基础知识相比于其他语言来说,语法可以不用花很多时间的过一遍的,正好我们这学期开设了这门课程,索性我也就跟着再次熟悉一遍Python的基础知识并把它总结出来,之前学习的时候写过笔记但是现在感觉还是总结成博客的形式比较好,也方便后续的复习。

最后,谢谢阅读完的朋友们,我也期待着得到你们的支持,谢谢!

目录
相关文章
|
6天前
|
存储 索引 Python
Python学习笔记----列表、元组和字典的基础操作
这篇文章是一份Python学习笔记,涵盖了列表、元组和字典的基础操作,包括它们的创建、修改、删除、内置函数和方法等。
Python学习笔记----列表、元组和字典的基础操作
|
7天前
|
算法 程序员 开发工具
百万级Python讲师又一力作!Python编程轻松进阶,豆瓣评分8.1
在学习Python的旅程中你是否正在“绝望的沙漠”里徘徊? 学完基础教程的你,是否还在为选择什么学习资料犹豫不决,不知从何入手,提高自己?
百万级Python讲师又一力作!Python编程轻松进阶,豆瓣评分8.1
|
1天前
|
Shell 数据处理 C++
【震撼揭秘】Python正则VS Shell正则:一场跨越编程边界的史诗级对决!你绝不能错过的精彩较量,带你领略文本处理的极致魅力!
【8月更文挑战第19天】正则表达式是文本处理的强大工具,在Python与Shell中有广泛应用。两者虽语法各异,但仍共享许多基本元素,如`.`、`*`及`[]`等。Python通过`re`模块支持丰富的功能,如非捕获组及命名捕获组;而Shell则依赖`grep`、`sed`和`awk`等命令实现类似效果。尽管Python提供了更高级的特性和函数,Shell在处理文本文件方面仍有其独特优势。选择合适工具需根据具体需求和个人偏好决定。
|
5天前
|
算法 程序员 开发工具
百万级Python讲师又一力作!Python编程轻松进阶,豆瓣评分8.1
在学习Python的旅程中你是否正在“绝望的沙漠”里徘徊? 学完基础教程的你,是否还在为选择什么学习资料犹豫不决,不知从何入手,提高自己?
|
3天前
|
数据采集 存储 人工智能
掌握Python编程:从基础到进阶的实用指南
【8月更文挑战第17天】 本文旨在通过浅显易懂的语言和实际案例,为初学者和有一定基础的开发者提供一条清晰的Python学习路径。我们将从Python的基本语法入手,逐步深入到面向对象编程、数据科学应用及网络爬虫开发等高级主题。每个部分都配备了代码示例和实操建议,确保读者能够将理论知识转化为实际能力。无论你是编程新手,还是希望提升Python技能的开发者,这篇文章都将为你打开一扇通往高效编程世界的大门。
7 2
|
8天前
|
索引 Python
Day 7/100:Python列表
Day 7/100:Python列表
9 1
|
8天前
|
Python
python Process 多进程编程
python Process 多进程编程
19 1
|
10天前
|
存储 数据库 C++
"深入剖析Python元组(tuple):与列表的对比、特性解析及高效应用场景展示"
【8月更文挑战第9天】Python元组与列表虽均用于存储元素集合,但有本质差异。元组不可变,创建后无法修改,适合保护数据不被意外更改的场景,如作字典键或传递固定值。列表则可变,支持动态增删改,适用于需频繁调整的数据集。元组因不可变性而在性能上有优势,可用于快速查找。两者各有千秋,根据具体需求选择使用。例如,元组可用于表示坐标点或日期,而列表更适合管理用户列表或库存。
16 1
|
1天前
|
机器学习/深度学习 Ubuntu 数据挖掘
揭秘:Ubuntu系统下部署Anaconda环境及Python语言的终极指南!跟随这一步步神秘流程,解锁编程大师的秘密武器!
【8月更文挑战第19天】在Ubuntu中部署Anaconda环境与Python相当直观。首先需从官网下载Linux版安装包。接着,在终端依次执行命令:添加Anaconda清华镜像源至软件源列表,更新软件包信息,然后安装Anaconda。安装后可通过`anaconda --version`验证。使用`anaconda create -n myenv python=3.8`创建名为“myenv”的环境并指定Python 3.8版本。
|
4天前
|
存储 数据安全/隐私保护 索引
Python基础语法day02字符串详解和列表
Python基础语法day02字符串详解和列表