python教程从基础到精通,第5课—List列表
wptr33 2024-12-24 16:01 30 浏览
python教程从基础到精通,第5课—List列表
Hello,小伙伴们,又见面啦!
上一章节咱们已学习了七大数据类型的Number(数字)、Boolean(布尔类型)、String(字符串),今天咱们来研究进一步学习List(列表)。
1、List(列表)的定义
List的定义方法有很多种,下面以实例来讲,代码如下:
list1 = [] # 创建一个空列表,list1=list(),显示为[]
list2 = [1, 2, 3, 4, 5, 6, 7, 8, 9]
list3 = ['a', 'b', 'c', 'd', 'e', 'f', 'g']
list4 = list("abcdefg") # ['a', 'b', 'c', 'd', 'e', 'f', 'g']
list5 = ["abcdefg"] # 只有一个字符串元素
list6 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list7 = [1, 2, "hello", 'world'] # 4个元素,前2个为数字,后2个为字符串
是不是很简单,确实。但是如果要创建一个很多的列表呢?有没有更加便捷、高效的定义方法?当然有,我们可以在列表中使用推导式的方法来创建列表,示例代码如下:
lista = [] * 10 # []
listb = [1] * 10 # [1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
listc = [[] for i in range(10)] # [[], [], [], [], [], [], [], [], [], []]
listd = [i for i in range(1, 10)] # [1, 2, 3, 4, 5, 6, 7, 8, 9]
liste = ['1' for i in range(10)] # ['1', '1', '1', '1', '1', '1', '1', '1', '1', '1']
listf = [i * 2 for i in range(10) if i * 2 % 8 == 0] # [0, 8, 16]找出符合条件(i*2%8==0)的值
那么2维或多维列表又如何定义呢?咱们直接看例子:
list1 = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] #定义了一个3行3列的3维列表
list2 = [[1, 2, 3, 4, 5], 'dotcpp', {1, 2, 3, }, ('www', 'dotcpp', 'com')] #定义了一个包含列表、字符串、集合、元组的4维列表
#推导式创建方法如下:
my_list = [[i for i in range(1,7)] for j in range(1,7)]
print(my_list)
如果如下:
[[1, 2, 3, 4, 5, 6],
[1, 2, 3, 4, 5, 6],
[1, 2, 3, 4, 5, 6],
[1, 2, 3, 4, 5, 6],
[1, 2, 3, 4, 5, 6],
[1, 2, 3, 4, 5, 6]]
2、List(列表)的访问
先来定义一个List,如下:
list 1= ['red', 'green', 'blue', 'yellow', 'white', 'black']
list1总共有6个元素,分别是:'red', 'green', 'blue', 'yellow', 'white', 'black' 6个字符串元素,每个元素都有index索引与value值属性,整个列表有多少个元素可以用len()方法获得。
第1元素的index是0,第2个元素的index是1,以此类推;最后一个元素的index是len(list1)-1,也可以用-1表示,因此倒数第二个元素的索引是-2,其他类推。
要访问列表中的值可以通过索引来实现,例如:
list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
print(list1[0]) # red
print(list1[1]) # green
print(list1[5]) # black
print(list1[len(list1)-1]) # black
print(list1[-1]) # black
如果想知道某个元素的索引呢,可以通过以下代码获得:
list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
print(list1.index("blue")) # 2
3、List(列表)的切片
List列表切片是非常有用的功能,示例如下:
list1 = ['www', '.', 'test', '.', 'com', '.', 'cn']
print(list1) # ['www', '.', 'test', '.', 'com', '.', 'cn']
print(list1[6]) # 下标是从0开始的,[6]个元素:cn
print(list1[-2]) # 倒数第2个元素:.
print(list1[:3]) # 前3个元素:['www', '.', 'test']
print(list1[3:]) # 第3个元素之后的元素(不包含第3个字符):['.', 'com', '.', 'cn']
print(list1[2:6]) # 第2个元素之后到第6个元素组成的列表:['test', '.', 'com', '.']
print(list1[::2]) # 偶数位置的元素组成的列表:['www', 'test', 'com', 'cn']
print(list1[::-1]) # 逆置列表:['cn', '.', 'com', '.', 'test', '.', 'www']
4、列表的操作方法
1) 改变元素的值
列表的元素是可以改变的,上面讲了可以直接通过索引或下标来访问元素,那么我们可以在访问元素值的时候赋予其新的值,示例代码如下:
list6 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list6[0] = "orange"
list6[3] = 'purple'
print(list6) # ['orange', 'green', 'blue', 'purple', 'white', 'black']
2) 增加元素append()、extend()方法
list.append(obj),在列表末尾添加新的对象
list.extend(seq),在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
示例代码:
list1 = ['red', 'green', 'blue']
list2 = [1, 2, 3]
list1.append("grey")
print(list1) #['red', 'green', 'blue', 'grey']
list1.extend(list2)
print(list1) #['red', 'green', 'blue', 'grey', 1, 2, 3]
3) 插入元素insert()方法
list.insert(index,obj),在索引index位置插入对象obj
list2 = [1, 2, 3]
list2.insert(2,[7,8,9]) # 在索引为2的位置插入对象
print(list2) #[1, 2, [7, 8, 9], 3]
4) 删除元素remove()方法、pop()方法
list.remove(obj),移除列表中某个值的第一个匹配项
list.pop([index=-1]),移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
list6 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list6.remove('black')
print(list6) # ['red', 'green', 'blue', 'yellow', 'white']
list6.remove(list6[4])
print(list6) # ['red', 'green', 'blue', 'yellow']
a = list6.pop() # 默认删除最后一个,返回被删除的值
print(list6, a) # ['red', 'green', 'blue'] yellow
list6.pop(1) # 删除下标为1的值
print(list6) # ['red', 'blue']
5) 对列表进行排序sort()方法、reverse()方法
list.sort( key=None, reverse=False),对原列表按ASCII码进行排序,两个参数均可省。
list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list2 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list3 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list1.sort() #按字母顺序排序,['black', 'blue', 'green', 'red', 'white', 'yellow']
list2.sort(reverse=True) #按字母逆序排序,['yellow', 'white', 'red', 'green', 'blue', 'black']
list3.sort(key=len) #按长度排序, ['red', 'blue', 'green', 'white', 'black', 'yellow']
基中key可以是做函数,python有内置的函数可以直接用,常用的内置key函数包括:
(1)str.lower() / str.upper():将字符串转换为小写/大写字母后再进行比较。适用于字符串的大小写不敏感的情况。
例如,按照字符串的字母顺序排序:
lst = ['abc', 'A', 'Ab']
lst.sort(key=str.lower)
print(lst)
# 输出:['A', 'Ab', 'abc']
(2)abs():返回数值的绝对值。适用于按照数值大小排序的情况。
例如,按照数值的绝对值大小排序:
lst = [-3, 1, -2]
lst.sort(key=abs)
print(lst)
# 输出:[1, -2, -3]
(3)len():返回对象的长度。适用于按照对象大小排序的情况。
例如,按照字符串长度排序:
lst = ['abc', 'a', 'ab']
lst.sort(key=len)
print(lst)
# 输出:['a', 'ab', 'abc']
list.reverse(),反向列表中元素,代码如下:
list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list1.reverse()
print(list1) # ['black', 'white', 'yellow', 'blue', 'green', 'red']
6) 列表的清空clear()与复制copy()
list1 = ['red', 'green', 'blue']
list2 = [1, 2, 3]
list2 = list1.copy() # 列表被新的列表所覆盖
list1.clear() # 清空列表
print(list1) # []
print(list2) # ['red', 'green', 'blue']
7) 列表的的计数方法count()
list.count(obj),统计某个元素在列表中出现的次数
list1 = ['red', 'green', 'blue', 'red']
print(list1.count('blue')) # 1
print(list1.count('red')) # 2
5、其它相关方法或函数
示例代码:
list1 = ['red', 'green', 'blue', 'red']
str1 = "good boy"
print(len(list1)) # 4
print(max(list1)) # red
print(min(list1)) # blue
print(list(str1)) # ['g', 'o', 'o', 'd', ' ', 'b', 'o', 'y']
愉快学习的时光总是过得很快,一不小心又到结尾啦。
先来给自己一个奖励,双手举起,yeah!
有什么问题可以关注我/私信我/加好友,让我们一起成长吧。
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)