在编程中,列表(List)是一种常用的数据结构,用于存储一组有序的元素。列表是Python中的内置数据类型之一,它允许你在一个变量中存储多个值,并且这些值可以是不同的数据类型,包括整数、浮点数、字符串、其他列表等。

Python中的列表使用方括号 [] 来定义,其中的元素之间用逗号 , 分隔。以下是列表的基本概念和特点:

  1. 有序性(Ordered):列表中的元素是按照它们的顺序存储和访问的。这意味着你可以通过索引来访问列表中的特定元素。

  2. 可变性(Mutable):列表是可变的,这意味着你可以添加、删除或修改列表中的元素。这使得列表在需要动态存储数据时非常有用。

  3. 元素的多样性(Heterogeneous):列表中的元素可以是不同的数据类型,例如整数、浮点数、字符串等。甚至可以包含其他列表作为元素,创建嵌套列表。

  4. 支持切片(Slicing):你可以使用切片操作来获取列表中的子列表。这允许你在不修改原始列表的情况下提取和操作其中的一部分数据。

  5. 长度(Length):你可以使用内置函数 len() 来获取列表中元素的数量。

  6. 迭代(Iteration):你可以使用循环来迭代(遍历)列表中的元素,对每个元素执行特定的操作。

以下是创建和操作列表的一些基本示例:

# 创建一个列表
fruits = ["apple", "banana", "cherry"] # 获取列表长度
length = len(fruits) # 访问列表元素
first_fruit = fruits[0] # 获取第一个元素 # 修改列表元素
fruits[1] = "orange" # 添加元素到列表末尾
fruits.append("grape") # 删除列表中的元素
del fruits[0] # 删除第一个元素 # 迭代列表元素
for fruit in fruits:
print(fruit)

列表里可以放列表,也可以放任意不同数据类型的东西,函数、类、对象也都可以放入

a = ["张三丰", "张无忌", "张绍刚", [1,2,3,True,aaaa]]

案例列举:

  1. 列表也像字符串一样也有索引和切片和步长

    lst = ["金毛狮王", "张绍刚", "张无忌", "郭麒麟"]
    
    print(lst[0])
    print(lst[1:3])
    print(lst[::-1])

    运行结果:

    金毛狮王
    ['张绍刚', '张无忌']
    ['郭麒麟', '张无忌', '张绍刚', '金毛狮王']
  2. 索引如果超过范围会报错
    lst = ["金毛狮王", "张绍刚", "张无忌", "郭麒麟"]
    print(lst[3652]) # list index out of range

    运行结果:

        print(lst[3652])   # list index out of range
    ~~~^^^^^^
    IndexError: list index out of range
  3. 可以用for循环进行遍历
    lst = ["金毛狮王", "张绍刚", "张无忌", "郭麒麟"]
    
    for item in lst:
    print(item)

    运行结果:

    金毛狮王
    张绍刚
    张无忌
    郭麒麟
  4. 用len可以拿到列表的长度
    lst = ["金毛狮王", "张绍刚", "张无忌", "郭麒麟"]
    print(len(lst))

    运行结果:

    4

列表用单引号或双引号括

lst1 = ['赵敏', "张无忌", "武则天", '嬴政', '马超']
lst2 = [赵敏, 张绍刚, 张无忌, 武则天, 嬴政, 马超]

这两个lst列表之间有一个关键区别,即它们包含的元素类型不同。

lst1 = ['赵敏', "张无忌", "武则天", '嬴政', '马超']
print(lst)

lst1是一个包含字符串元素的列表。每个元素都是用单引号或双引号括起来的字符串。

lst2 = [赵敏, 张绍刚, 张无忌, 武则天, 嬴政, 马超]
print(lst2)

执行结果

Traceback (most recent call last):
File "D:\Python\test.py", line 40, in <module>
lst2 = [赵敏, 张绍刚, 张无忌, 武则天, 嬴政, 马超]
^^
NameError: name '赵敏' is not defined

lst2看起来似乎包含了未引用的标识符,这会导致语法错误。通常情况下,标识符(变量名)应该使用单引号或双引号括起来,以表示它们是字符串。如果没有括起来,Python会将它们解释为变量名,而不是字符串。

如果你的意图是将这些元素视为字符串,那么你应该使用引号将它们括起来,就像第一个lst1一样:

lst1 = ['赵敏', "张无忌", "武则天", '嬴政', '马超']

如果你的意图是将这些元素视为变量名,那么你需要确保这些变量已经定义,否则会导致NameError。例如,如果你已经定义了这些变量,那么第二个lst2将是有效的:

赵敏 = "赵敏" 张绍刚 = "张绍刚" 张无忌 = "张无忌" 武则天 = "武则天" 嬴政 = "嬴政" 马超 = "马超"
lst2 = [赵敏, 张绍刚, 张无忌, 武则天, 嬴政, 马超]
print(lst2)

列表的排序

1、列表会按照你存放的顺序来保存

lst = [1, 2, 3, "麻花藤", "武大郎"]
print(lst)

2、对列表进行升序、降序排序

lst = [222, 444, 123, 43, 123,43243, 111]
lst.sort() # 对列表进行升序排序
lst.sort(reverse=True) # reverse: 翻转
print(lst)

列表的嵌套

lst = ["abc", "def", ["呵呵哒", "妈妈呀", "苦苦脊瓦", ["可乐", "scrapy", 123]], 'aed', "qpr"]
print(lst[2][3][1])
lst[2][3][1] = lst[2][3][1].upper()
print(lst)

列表的循环删除(*)

错误操作

lst = ['赵敏', '张绍刚', '张无忌', '武则天', '嬴政', '马超']

for item in lst:
if item.startswith("张"):
lst.remove(item) # 有bug
print(lst)

输出结果:

['赵敏', '张无忌', '武则天', '嬴政', '马超']

上面这个代码的目的是从一个列表中删除所有以"张"开头的元素。不过,这个代码在Python中有一个常见的问题。当你试图在迭代一个列表的同时修改它时,会出现一个错误。因为在迭代过程中修改列表会影响迭代器的状态。

安全稳妥的循环删除方式:

将要删除的内容保存在一个新列表中. 循环新列表. 删除老列表

lst = ['赵敏', '张绍刚', '张无忌', '武则天', '嬴政', '马超']

temp = [] # 准备一个临时列表, 负责存储要删除的内容
for item in lst:
if item.startswith("张"):
# lst.remove(item) # 有bug
temp.append(item) # 把要删除的内容记录下来 for item in temp:
lst.remove(item) # 去原列表中进行删除操作
print(lst)

Python——第二章:列表的概念的更多相关文章

  1. Python 第二章-列表和元组

    第二章-列表和元组 2.0      在Python中,最基本的数据结构是序列(sequence).序列中的每个元素被分配一个序列号-即元素的位置, 也称为索引.第一个索引是0,第二个是1,以此类推. ...

  2. 简学Python第二章__巧学数据结构文件操作

    #cnblogs_post_body h2 { background: linear-gradient(to bottom, #18c0ff 0%,#0c7eff 100%); color: #fff ...

  3. machine learn in python 第二章2.1.1

    1大约 sklearn.datasets from sklearn.datasets import load_iris import numpy as np data = load_iris() da ...

  4. python基础教程-第二章-列表和元组

    本章将引入一个新的概念,:数据结构.数据结构是通过某种方式(例如对元素进行编号)组织在 一起的数据元素的集合,这些数据元素可以是数字或者字符,甚至可以是其他数据结构.在python中,最基本的数据结构 ...

  5. 《Python基础教程(第二版)》学习笔记 -> 第二章 列表和元组

    本章将引入一个新的概念:数据结构. 数据结构是通过某种方式阻止在一起的数据元素的集合,这些数据元素可以是数字或者字符,设置可以是其他数据结构. Python中,最基本的数据结构是序列(Sequence ...

  6. python第二章(2)列表

    names=["zhangyang","guyun","xiangpeng","leiming","xulia ...

  7. Python基础教程学习笔记:第二章 列表和元组

    1.序列中元素的索引: 第一个元素索引是0,第二个是1,依次递增 最后一个元素索引是-1,倒数第二个是-2,依次递减 2.序列(Sequence)的种类: 列表(list).元组(tuple).字符串 ...

  8. Python基础教程 读书笔记(2)第二章 列表和元组

    2.1序列概览 列表和元组的主要区别在于,列表可以修改,元组则不能.也就是说如果要根据要求来添加元素,那么列表可能会更好用;而出于某些原因,序列不能修改的时候,使用元组则更为合适.使用后者的理由通常是 ...

  9. 20190804-Python基础 第二章 列表和元组

    容器,Python支持一种数据结构的基本概念(容器,基本上就是可包含其他对象的对象.) 两种主要的容器是:序列(如列表和元组)和映射(如字典) Ps: 列表与元组区别,列表可修改,元组不能. 对序列的 ...

  10. python第二章:数据类型--小白博客

    标准数据类型 Python3 中有六个标准的数据类型: Number(数字) String(字符串) List(列表) Tuple(元组) Set(集合) Dictionary(字典) Python3 ...

随机推荐

  1. SpringBoot进阶教程(七十七)WebSocket

    WebSocket是一种在单个TCP连接上进行全双工通信的协议.WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据.在WebSocket API中,浏览器和 ...

  2. redis 源码分析:Jedis 哨兵模式连接原理

    1. 可以从单元测试开始入手 查看类JedisSentinelPool private static final String MASTER_NAME = "mymaster"; ...

  3. Redis系列之——使用常见问题

    文章目录 一 子进程开销和优化 二 fork操作 三 aof追加阻塞 一 子进程开销和优化 1 cpu 开销:rdb和aof文件生成,属于cpu密集型 优化:不做cpu绑定,不和cpu密集型的服务一起 ...

  4. WEB项目开发流程介绍

    web开发流程 web开发流程图 一.需求分析阶段 在需求分析阶段,即上图所述 "需求明确"之前的阶段 产品经理PM召集需要项目相关人员,开需求讨论会.讲解原型 相关人员需要以此了 ...

  5. Java虚拟机(JVM):第五幕:自动内存管理 - HotSpot算法细节以及低延迟垃圾收集器

    一.HotSpot算法细节 1.根节点枚举:所有的收集器在根节点枚举的时候,必须暂停用户线程,同时要保证一致性的快照中得以进行.一致性:整个枚举期间执行子系统看起来就像是冻结在某一个时间点上,不会出现 ...

  6. CF82D Two out of Three

    题目描述 Vasya has recently developed a new algorithm to optimize the reception of customer flow and he ...

  7. node版本依赖报错那些事儿

    前言 昨天还能跑的的项目,今天就歇菜了 第一步 删除大法 依赖问题,那就把.lock/ node_modules 删除重新装 第二步 如果重装不好使,那就各种降低版本尝试 遇到这样的 有两种方式 1. ...

  8. [SWPUCTF 2021 新生赛]非常简单的逻辑题

    一道简单的代码逆向,根据提供的py代码写出逆向代码,没怎么做过这种题开始没什么思路,原来直接暴力就好 直接写出暴力代码

  9. Java核心知识体系6:集合框架详解

    Java核心知识体系1:泛型机制详解 Java核心知识体系2:注解机制详解 Java核心知识体系3:异常机制详解 Java核心知识体系4:AOP原理和切面应用 Java核心知识体系5:反射机制详解 1 ...

  10. 2022.7.13 tongyf 讲课纪要

    前言 这个笔记记晚了,主要是都在跟 \(LCT\) 进行殊死搏斗,所以博客这方面就挂了很久. tongyf 学长当年是拿到省一之后省选炸了,之后暴切高考.ORZ%%% 这节课讲的是线性dp和背包dp, ...