编程语言
首页 > 编程语言> > (Python学习笔记):列表

(Python学习笔记):列表

作者:互联网

目录

列表的应用场景

列表的格式

列表的常用操作

查找

判断是否存在

增加

删除

修改

复制

列表的循环遍历

while

for

列表嵌套

总结

列表的应用场景

  • 如果一个班级100位学生,每个人的姓名都要存储,应该如何书写程序?声明100个变量吗?
  • 使用列表即可,列表一次性可以存储多个数据。

列表的格式

[数据1, 数据2, 数据3, 数据4......]
  • 列表可以一次性存储多个数据,且可以为不同数据类型

列表的常用操作

  • 列表的作用是一次性存储多个数据,程序员可以对这些数据进行的操作有:增、删、改、查。

查找

【下标】

name_list = ['TOM', 'Lily', 'ROSE']

print(name_list)

print(name_list[1])
print(name_list[0])
print(name_list[2])

【函数】

index()

  • 返回指定数据所在位置的下标 。
列表序列.index(数据, 开始位置下标, 结束位置下标)
  • 示例
name_list = ['Tom', 'Lily', 'Rose']
print(name_list.index('Lily', 0, 2)) # 1
  • 注意:如果查找的数据不存在则报错。

【count()】

  • 统计指定数据在当前列表中出现的次数。
name_list = ['TOM', 'Lily', 'ROSE']

print(name_list.count('TOM'))
print(name_list.count('TOMS'))

【len()】

  • 访问列表长度,即列表中数据的个数
name_list = ['TOM', 'Lily', 'ROSE']

print(len(name_list))

判断是否存在

【in】

  • 判断指定数据在某个列表序列,如果在返回True,否则返回False
name_list = ['TOM', 'Lily', 'ROSE']

print('TOM' in name_list)
print('TOMS' in name_list)

【not in】

  • 判断指定数据不在某个列表序列,如果不在返回True,否则返回False
name_list = ['TOM', 'Lily', 'ROSE']

print('TOM' not in name_list)
print('TOMs' not in name_list)

【示例】

  • 需求:查找用户输入的名字是否已经存在。
name_list = ['Tom', 'Lily', 'Rose']

name = input('请输⼊您要搜索的名字: ')
if name in name_list:
    print(f'您输⼊的名字是{name}, 名字已经存在')
else:
    print(f'您输⼊的名字是{name}, 名字不存在')

增加

  • 作用:增加指定数据到列表中

【append()】

  • 列表结尾追加数据。
列表序列.append(数据)
  • 示例
name_list = ['TOM', 'Lily', 'ROSE']

name_list.append('xiaoming')
name_list.append([11, 22])

print(name_list)

  • 列表追加数据的时候,直接在原列表里面追加了指定数据,即修改了原列表,故列表为可变类型数据
  • 如果append()追加的数据是一个序列,则追加整个序列到列表

【extend()】

  • 列表结尾追加数据,如果数据是一序列,则将这个序列的数据逐一添加到列表。
列表序列.extend(数据)
  • 单个数据
name_list = ['Tom', 'Lily', 'Rose']

name_list.extend('xiaoming')

# 结果: ['Tom', 'Lily', 'Rose', 'x', 'i', 'a', 'o', 'm', 'i', 'n', 'g']
print(name_list)
  • 序列数据
name_list = ['Tom', 'Lily', 'Rose']
name_list.extend(['xiaoming', 'xiaohong'])

# 结果: ['Tom', 'Lily', 'Rose', 'xiaoming', 'xiaohong']
print(name_list)

【insert()】

  • 指定位置新增数据
列表序列.insert(位置下标, 数据)
name_list = ['Tom', 'Lily', 'Rose']
name_list.insert(1, 'xiaoming')

# 结果: ['Tom', 'xiaoming', 'Lily', 'Rose']
print(name_list)

删除

【del】

del ⽬标
  • 删除列表
name_list = ['Tom', 'Lily', 'Rose']

del name_list
print(name_list)

  • 删除指定数据
name_list = ['Tom', 'Lily', 'Rose']
del name_list[0]

print(name_list)

【pop()】

  • 删除指定下标的数据(默认为最后一个),并返回该数据。
列表序列.pop(下标)
name_list = ['Tom', 'Lily', 'Rose']
del_name = name_list.pop(1)

print(del_name)
print(name_list)

【remove()】

  • 移除列表中某个数据的第一个匹配项。
列表序列.remove(数据)
name_list = ['Tom', 'Lily', 'Rose']
name_list.remove('Rose')
 
print(name_list)

【clear()】

  • 清空列表
name_list = ['Tom', 'Lily', 'Rose']
name_list.clear()

print(name_list) # 结果: []

修改

  • 修改指定下标的数据
name_list = ['Tom', 'Lily', 'Rose']
name_list[0] = 'aaa'

# 结果: ['aaa', 'Lily', 'Rose']
print(name_list)

【逆置: reverse()】

num_list = [1, 5, 2, 3, 6, 8]
num_list.reverse()

# 结果: [8, 6, 3, 2, 5, 1]
print(num_list)

【排序: sort()】

列表序列.sort( key=None, reverse=False)
  • 注意:reverse表示排序规则,reverse=True降序,reverse=False升序(默认)
num_list = [1, 5, 2, 3, 6, 8]
num_list.sort()

# 结果: [1, 2, 3, 5, 6, 8]
print(num_list)

复制

【函数: copy()】

name_list = ['Tom', 'Lily', 'Rose']
name_li2 = name_list.copy()

# 结果: ['Tom', 'Lily', 'Rose']
print(name_li2)

列表的循环遍历

  • 需求:依次打印列表中的各个数据。

while

name_list = ['Tom', 'Lily', 'Rose']
i = 0
while i < len(name_list):
    print(name_list[i])
    i += 1

for

name_list = ['Tom', 'Lily', 'Rose']
for i in name_list:
    print(i)

 

列表嵌套

  • 所谓列表嵌套指的就是一个列表里面包含了其他的子列表
  • 应用场景:要存储班级一、二、三三个班级学生姓名,且每个班级的学生姓名在一个列表。
name_list = [['⼩明', '⼩红', '⼩绿'], ['Tom', 'Lily', 'Rose'], ['张三', '李四','王五']]

# 第⼀步:按下标查找到李四所在的列表
print(name_list[2])

# 第⼆步:从李四所在的列表⾥⾯,再按下标找到数据李四
print(name_list[2][1])

总结

  • 列表的格式
[数据1, 数据2, 数据3]
  • 常用操作方法
    • index()
    • len()
    • append()
    • pop()
    • remove()
  • 列表嵌套
name_list = [['⼩明', '⼩红', '⼩绿'], ['Tom', 'Lily', 'Rose'], ['张三', '李四',
'王五']]
name_list[2][1]

 

标签:name,Python,Rose,list,笔记,列表,print,Lily
来源: https://blog.csdn.net/baidu_41388533/article/details/110750031