引言
列表
list
是由一系列按照特定顺序排列的元素组成的,它是一种有序的数据集合。
你可以添加任何类型的元素到列表中,其中的元素之间可以没有任何关系。
列表简介
Python 使用方括号
[]
来定义列表,列表中的每个值称为元素。
每个元素之间用逗号,
分割开,每个元素都有自己唯一的索引值。
索引值分上标索引和下标索引,下标索引从0
开始,上标索引从-1
开始。
你可以理解为:下标索引 = 正序索引,上标索引 = 倒序索引
创建列表
一般将创建的列表赋给一个变量,因此给变量取个有意义的名字是个不错的注意
打印列表时,会将方括号[]
也打印出来
如果你想定义一个空列表可以直接使用方括号 []
而不在里面传值
定义一个人员列表,如下示例。
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八']
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八']
列表取值
列表有两种取值方式
- 按索引号取值
- 范围取值
按索引号取值
在列表变量后面加上方括号 []
里面传入元素的索引号,如下示例
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons[0])
# 运行结果:张三
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons[0])
# 运行结果:张三
范围取值
范围取值只需在方括号内传入两个参数,即 [开始索引:结束索引]
Python 遵循左闭右开原则,即包含左边的而不包含右边的,所以实际取到的最后一个值是 结束索引-1。
1. 列表范围取值
例如取值 1~3 位置的元素,实际只取值到 1~2 位置的元素,如下示例
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons[0:3])
# 运行结果:['张三', '李四', '王五']
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons[0:3])
# 运行结果:['张三', '李四', '王五']
2. 范围取值指定步长
范围取值可以指定步长,只需传入3个参数,即 [开始索引:结束索引:指定步长]
如果你想范围取值的时候隔一个或N个元素取值,指定步长是个不错的注意。
# 隔一个元素取值
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons[0:5:2])
# 运行结果:['张三', '王五', '钱七']
# 隔一个元素取值
persons = ['张三','李四','王五','赵六','钱七','孙八']
print(persons[0:5:2])
# 运行结果:['张三', '王五', '钱七']
取值索引越界问题
注意: 列表取值时索引不能越界,如果取值索引超出列表的索引范围,会报一个
IndexError
的错误
# 例如以下示例
persons = ['张三', '李四', '王五']
print(persons[3])
# 运行报出错误:IndexError: list index out of range
# 翻译过来就是“列表索引超出范围”,因为列表中索引位置 3 根本没有任何元素
# 例如以下示例
persons = ['张三', '李四', '王五']
print(persons[3])
# 运行报出错误:IndexError: list index out of range
# 翻译过来就是“列表索引超出范围”,因为列表中索引位置 3 根本没有任何元素
新增
列表的新增操作
1. 在指定位置插入元素 insert()
# 插入元素
persons = ['张三','李四','王五','赵六','钱七','孙八']
persons.insert(6,'杨九')
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九']
# 插入元素
persons = ['张三','李四','王五','赵六','钱七','孙八']
persons.insert(6,'杨九')
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九']
2. 方法在列表末尾追加元素 append()
# 在末尾追加元素
persons = ['张三','李四','王五','赵六','钱七','孙八']
persons.append('杨九')
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九']
# 在末尾追加元素
persons = ['张三','李四','王五','赵六','钱七','孙八']
persons.append('杨九')
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九']
3. 在列表末尾追加多个元素 extend()
使用
extend()
方法在末尾同时追加多个元素
# 同时在末尾追加多个元素
persons = ['张三','李四','王五','赵六','钱七','孙八']
persons.extend(['杨九','吴十'])
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
# 同时在末尾追加多个元素
persons = ['张三','李四','王五','赵六','钱七','孙八']
persons.extend(['杨九','吴十'])
print(persons)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
删除
列表的删除操作
1. 按索引号弹出元素 pop()
pop()
有返回值,弹出的元素可以保存到一个新的变量中,以便下次使用,也可以不保存,不保存就是删除
以下示例中很好的体现了 pop()
弹出的元素能够保存到另一个变量中
persons = ['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.pop(0)
print(persons) # 运行结果:['李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
print(persons2) # 运行结果:张三
persons = ['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.pop(0)
print(persons) # 运行结果:['李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
print(persons2) # 运行结果:张三
2. 按元素名称移除元素 remove()
值得注意的是,如果列表中存在多个相同的元素,
remove()
方法只会移除正序索引遇到的第一个元素,如果想移除全部可以使用遍历
persons = ['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons.remove('张三')
print(persons) # 运行结果:['李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons = ['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons.remove('张三')
print(persons) # 运行结果:['李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
3. 删除元素 del
del 是Python的语句,而不是列表
list
的方法,del是传入索引号删除的,但没有返回值
persons = ['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
del persons[0]
print(persons) # 运行结果:['李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons = ['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
del persons[0]
print(persons) # 运行结果:['李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
其他
列表的一些其他使用方法
1. len()
函数
使用
len()
函数看列表共有几个元素
persons = ['张三','李四','王五','赵六','钱七','孙八']
print( len(persons) ) # 运行结果:6
persons = ['张三','李四','王五','赵六','钱七','孙八']
print( len(persons) ) # 运行结果:6
2. count()
函数
使用
count()
方法查看元素在列表中出现几次
# 获取元素 李四 在列表中出现几次
persons = ['张三','李四','王五','李四','赵六','钱七','孙八']
cnt = persons.count('李四')
print(cnt) # 运行结果:2
# 获取元素 李四 在列表中出现几次
persons = ['张三','李四','王五','李四','赵六','钱七','孙八']
cnt = persons.count('李四')
print(cnt) # 运行结果:2
3. 使用 index()
函数查看元素索引号
index()
方法只返回遇到的第一个符合条件的元素,如果有多个重复的元素名称需要使用遍历
如下示例,查看元素 ”李四“ 的索引号时只返回遇到的第一个元素
persons = ['张三','李四','王五','李四','赵六','钱七','孙八']
print( persons.index('李四') )
# 运行结果:1
persons = ['张三','李四','王五','李四','赵六','钱七','孙八']
print( persons.index('李四') )
# 运行结果:1
遍历获取 “李四” 的索引号,如下示例
persons = ['张三','李四','王五','李四','赵六','钱七','孙八']
i = 0
for p in persons:
if p == '李四':
print(i,end='\t')
i += 1
# 运行结果:1 3
persons = ['张三','李四','王五','李四','赵六','钱七','孙八']
i = 0
for p in persons:
if p == '李四':
print(i,end='\t')
i += 1
# 运行结果:1 3
4. 使用 copy()
方法复制列表
复制出来的列表是一份独立全新的数据,更改原列表内容不会影响复制的列表
# 复制列表
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.copy()
persons.remove('李四')
print(persons) # 运行结果:['张三', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
print(persons2) # 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
# 复制列表
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.copy()
persons.remove('李四')
print(persons) # 运行结果:['张三', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
print(persons2) # 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
5. 分割列表 split()
将字符串数据按特定规则分割成列表
例如以下示例, persons
变量中存储的字符串,每个人员用逗号 ,
分割开,使用 split()
方法可以让其分割成列表
persons = '张三,李四,王五,赵六,钱七,孙八,杨九,吴十'
persons_list = persons.split(',')
print(persons_list)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons = '张三,李四,王五,赵六,钱七,孙八,杨九,吴十'
persons_list = persons.split(',')
print(persons_list)
# 运行结果:['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
6. 成员运算符 in
判断数据是否存在列表中
# 使用成员运算符判断张三是否存在 `persons` 列表中
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = '张三'
print(persons2 in persons)
# 运行结果:True
# 使用成员运算符判断张三是否存在 `persons` 列表中
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = '张三'
print(persons2 in persons)
# 运行结果:True
7. 身份运算符 is
判断两个变量是否使用同一内存地址,是否指向同一块内存空间
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.copy()
persons3 = persons
print(persons2 is persons) # 运行结果:False
print(persons3 is persons) # 运行结果:False
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.copy()
persons3 = persons
print(persons2 is persons) # 运行结果:False
print(persons3 is persons) # 运行结果:False
8. 清空列表内容 clear()
以下清空列表示例中很好的展示了
copy()
出来的数据是一块独立全新的数据,清空persons
列表的内容对它丝毫不受影响
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.copy()
persons3 = persons
persons.clear()
print(persons)
print(persons2)
print(persons3)
'''
运行结果:
[]
['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
[]
'''
persons = ['张三' , '李四' , '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
persons2 = persons.copy()
persons3 = persons
persons.clear()
print(persons)
print(persons2)
print(persons3)
'''
运行结果:
[]
['张三', '李四', '王五', '赵六', '钱七', '孙八', '杨九', '吴十']
[]
'''
数据之心