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

python数据类型(三):列表 python 列表类型

wptr33 2024-12-24 16:02 49 浏览

列表是Python中最具灵活性的有序集合对象类型,可以包含任何类型的对象,如字符串、数字、甚至其他列表。? 列表是可变的数据类型,即这种类型的值是可以被修改的?。列表的基本操作包括创建、访问、更新、删除元素等。

在 Python 中,列表是使用方括号 “[]” 编写的,在列表中使用“逗号(,)”来将列表中的元素隔断。当“[]”内没有元素时,该列表为空。

list1 = [22,45.32,"Python",["holle","word"],True] 
# 含有五个元素的列表,其中["holle","word"]作为列表,是list1中一个单独的元素
list2 = [] # 空列表

boundary-end ------

注意:len() 内置函数表示变量的长度,常用在字符串,列表循环中

一、 索引

正向索引与反向索引,其实就是从左往右是0,1,2,3,。。。 ; 从右往左是-1,-2,-3,。。。

list1 = [22,45.32,"Python",["holle","word"],True]
# 22  45.32  'Python'  ['holle', 'word']  True
# 0    1        2            3              4
print(list1[2])
# 输出结果为"Python"
list1 = [22,45.32,"Python",["holle","word"],True]
# 22  45.32  'Python'  ['holle', 'word']  True
# -5    -4        -3            -2         -1
print(list1[-3])
# 输出结果为"Python"

索引切片

索引用来对单个成员(元素)进行访问,切片则是对一定范围内的成员(元素)进行访问

切片通过冒号的方式在中括号内把相隔的两个索引位置范围内的成员(元素)找出来,如 0:10

切片的规则:左含,右不含; 左边包含,右边不包含

通过切片方式获取的完整的列表已经不再是原来的列表了,即使获取的是原来列表的完整的内容

num_list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
print(num_list[3:7])
>>> [4, 5, 6, 7]
num_list = [1, 2, 3, 4, 5, 6, 7, 8]
print(num_list[::-1]) # 列表的反序
print(num_list[-3:-1]) # 列表的反向获取
print(num_list[0:8:2]) # 列表的步长获取:【每隔2步长(也可以理解为每两个数值)获取索引0到8的元素】




>>> [8, 7, 6, 5, 4, 3, 2, 1]
>>> [6, 7]
>>> [1, 3, 5, 7]
  • 可以通过list.index(item) 列表通过 index() 函数,传入一个元素来获取当前元素的索引值

二、 转化

join(): 连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串

(1)列表转化字符串

将列表中的元素转化为字符串时,使用一个空字符串接收由列表转换的字符串。

可使用内置函数“str”直接将列表转换为字符串,但是这种方法会将列表中的“[]”“,”以及引号也作为字符串进行转化

list1 = ["a","b","c","d","e"]
str1 = str(list1)
print(str1)
# 输出结果为:['a', 'b', 'c', 'd', 'e'] , <class 'str'>

也可使用字符拼接的“join拼接方法”。转换为字符串时,列表内的元素也只能是字符串。

list1 = ["a","b","c","d","e"]
str1 = "".join(list1)
print(str1)
# 输出结果为:abcde

(2)字符串转化为列表

将字符串转化为列表,可以使用内置函数“list”直接将字符串转化为列表。

str1 = "abcde"
list1 = list(str1)
print(list1)
# 输出结果为:['a', 'b', 'c', 'd', 'e']

三、 操作

(1.0)添加单个元素 :append() , 元素添加为位置在列表的最后。

(1.1)添加多个元素 :extend(), 元素添加为位置在列表的最后,但是会给每个元素进行拆分后添加

注:如果添加的是字符串那么元素会被拆分,如果是添加的是数组,元素不会被拆分

(1.2)制定位置添加元素 :insert()

list1 = list1 = ['a', 'b', 'c', 'd', 'e']
list1.append('f')
print(list1)
# 输出结果为:['a', 'b', 'c', 'd', 'e', 'f']




list1 = ['a', 'b', 'c', 'd', 'e']
list1.extend("fh")
print(list1)
# 输出结果为:['a', 'b', 'c', 'd', 'e', 'f', 'h']
list1 = ['a', 'b', 'c', 'd', 'e']
list1.extend(["fh"])
print(list1)
# 输出结果为:['a', 'b', 'c', 'd', 'e', 'fh']




list1 = ['a', 'b', 'c', 'd', 'e']
list1.insert(0,'h')
print(list1)
# 输出结果为:['h', 'a', 'b', 'c', 'd', 'e']

(2.0)修改 :

直接赋值即可

list1 = ['a', 'b', 'e','c', 'd', 'e']
list1[1] = 'j' #修改“b”为“j”
print(list1)
# 输出结果为:['a', 'j', 'e', 'c', 'd', 'e']

(3.0)删除del() : 根据下标删除,一般不用

(3.1)删除pop : 删除列表最后一个或指定位置元素,当pop内未指明下标时,默认删除最后一位元素。

list1 = ['a', 'b', 'c', 'd', 'e']
list1.pop() # 删除“e”
print(list1)
# 输出结果为:['a', 'b', 'c', 'd']
 
list1 = ['a', 'b', 'c', 'd', 'e']
list1.pop(2) # 删除“c”
print(list1)
# 输出结果为:['a', 'b', 'd', 'e']

(3.2)删除remove: 删除指定的元素,如果元素没有会报错

list1 = ['a', 'b', 'e','c', 'd', 'e']
list1.remove('e') # 删除“e”
print(list1)
# 输出结果为:['a', 'b', 'c', 'd', 'e']

(3.3)清除clear:删除列表所有元素,列表变成[],和del不一样,del是彻底删除这个列表

list1 = ['a', 'b', 'e','c', 'd', 'e']
list1.clear()
print(list1)
# 输出结果为:[]

其他不常用操作:

sort在排序时,是在对原列表本身进行改变,不需要另外一个空列表来进行接收,没有返回值。

sorted在排序时,并不是对原列表本身进行改变,这时需要一个空列表进行接收排序后的列表,有返回值。

reverse可以对列表进行逆序排序,当reverse的值等于True时,进行逆序排序;当reverse的值等于False时,进行正序排序。

copy:复制列表,生成一个完全新的列表

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

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+树),用于...