列表的元素的数据类型可以不一致。
建
[ ]。 创建一个列表,只要把逗号分隔的不同的数据项使用方括号括起来即可。如下所示:
list1 = ['Google', 'Runoob', 1997, 2000]
list2 = [1, 2, 3, 4, 5 ]
list3 = ["a", "b", "c", "d"]
list4 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list()函数
print(list("yiyayo"))
print(list(str(1234)))
print(list(range(4)))
###
['y', 'i', 'y', 'a', 'y', 'o']
['1', '2', '3', '4']
[0, 1, 2, 3]
列表解析(list comprehension)
list1=[i**2 for i in range(1,10)]
print(f"list1={list1}")#list1=[1, 4, 9, 16, 25, 36, 49, 64, 81]
其它生成列表的函数
string.split()
re.findall(str1,str2)
查
列表索引从 0 开始,第二个索引是 1,依此类推。
1、索引也可以从尾部开始,最后一个元素的索引为 -1,往前一位为 -2,以此类推。
2、可以通过索引列表可以进行截取、组合等操作。
3、切片访问
listname[start:end:step=1]
start 默认为0,通常不包含指定end,不指定 end 时访问到最后一个元素。
step默认为1,即连续访问元素,step的方向(负数表示从右到左)必须与start到end的方向一致,否则输出空列表。
#!/usr/bin/python3
list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
print( list1[0] )#red
print( list[1] )#green
print( list1[-1] )#black
print( list1[-2] )#white
print(list[0:4])#['red', 'green', 'blue', 'yellow']
print(list1[:2])#['red', 'green']
print(list1[2:])#['blue', 'yellow', 'white', 'black']
print(list1[-3:-1])#['yellow', 'white']
print(list1[-1:-3])#[]
print(list1[-1:-3:-1])#['black', 'white']
print(list1[0:4:2])#['red', 'blue']
增
listname.append(obj)
listname.insert(index, obj)
# 增加列表元素1: append
kL=[2, 'Jump Shot', 'Los Angeles Lakers']
kL.append('POR')
print(kL)#[2, 'Jump Shot', 'Los Angeles Lakers', 'POR']
# 增加列表元素2: insert
kL=[2, 'Jump Shot','POR']
kL.insert(1,'Los Angeles Lakers')
print(kL)#[2, 'Los Angeles Lakers', 'Jump Shot', 'POR']
append将元素添加到最后
insert将元素添加到指定索引
删
del 可以删除列表中的单个元素,格式为
del listname[index]
其中,listname 表示列表名称,index 表示元素的索引值。del 也可以删除中间一段连续的元素,格式为:
del listname[start : end]
其中,start 表示起始索引,end 表示结束索引。del 会删除从索引 start 到 end 之间的元素,不包括 end 位置的元素。
remove():根据元素值进行删除
需要注意的是,remove() 方法只会删除第一个和指定值相同的元素,而且必须保证该元素是存在的,否则会引发 ValueError 错误。
remove() 方法使用示例:
nums = [40, 36, 89, 2, 36, 100, 7]
#第一次删除36
nums.remove(36)
print(nums)
#第二次删除36
nums.remove(36)
print(nums)
#删除78
nums.remove(78)
print(nums)
###
[40, 89, 2, 36, 100, 7]
[40, 89, 2, 100, 7]
ValueError: list.remove(x): x not in list
最后一次删除,因为 78 不存在导致报错,所以我们在使用 remove() 删除元素时最好提前判断一下。
pop():根据索引值删除元素
pop() 方法用来删除列表中指定索引处的元素,具体格式如下:
listname.pop(index=-1)
其中,listname 表示列表名称,index 表示索引值。如果不写 index 参数,默认会删除列表中的最后一个元素,类似于数据结构中的“出栈”操作。
nums = [40, 36, 89, 2, 36, 100, 7]
nums.pop(3)
print(nums)
nums.pop()
print(nums)
###
[40, 36, 89, 36, 100, 7]
[40, 36, 89, 36, 100]
clear():删除列表所有元素
用来删除列表的所有元素,也即清空列表,请看下面的代码:
url = list("http://c.biancheng.net/python/")
url.clear()
print(url)
###
[]
改
listname[index]=new_value
# 改写列表元素
L=[1, 2, 3, 4, 5]
L[1]=20
L[-1]=L[-1]*L[-2]
print(L)#[1, 20, 3, 4, 20]
操作符 + *
列表对 + 和 * 的操作符与字符串相似。+ 号用于组合列表,* 号用于重复列表。
Python 表达式 | 结果 | 描述 |
---|---|---|
len([1, 2, 3]) | 3 | 长度 |
[1, 2, 3] + [4, 5, 6] | [1, 2, 3, 4, 5, 6] | 组合 |
[‘Hi!’] * 4 | [‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’] | 重复 |
3 in [1, 2, 3] | True | 元素是否存在于列表中 |
for x in [1, 2, 3]: print(x, end=" ") | 1 2 3 | 迭代 |
list(string)
print(list("yiyayo"))
print(list(str(1234)))
###
['y', 'i', 'y', 'a', 'y', 'o']
['1', '2', '3', '4']
以索引为键转字典
list1=[i**2 for i in range(0,4)]
dict1={i:j for i,j in enumerate(list1)}
print(dict1)#{0: 0, 1: 1, 2: 4, 3: 9}
enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列
enumerate(sequence, [start=0])
函数与方法
序号 | 函数 |
---|---|
1 | len(list) 列表元素个数 |
2 | max(list) 返回列表元素最大值 |
3 | min(list) 返回列表元素最小值 |
4 | list(seq) 将序列转换为列表 |
下表中的“list”换成实际的 列表名
序号 | 方法 |
---|---|
1 | list.append(obj) 在列表末尾添加新的对象 |
2 | list.count(obj) 统计某个元素在列表中出现的次数 |
3 | list.extend(seq) 在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表) |
4 | list.index(obj) 从列表中找出某个值第一个匹配项的索引位置 |
5 | list.insert(index, obj) 将对象插入列表成为索引为 index 的元素 |
6 | list.pop(index=-1) 移除列表中的一个元素(默认最后一个元素),并且返回该元素的值 |
7 | list.remove(obj) 移除列表中某个值的第一个匹配项 |
8 | list.reverse() 反向列表中元素,无返回值 |
9 | list.sort( key=None, reverse=False) 对原列表进行排序,无返回值 |
10 | list.clear() 清空列表 |
11 | list.copy() 复制列表 |
关于sorted( )
sorted(seq, key=None),#返回排序结果,不改变原序列
#coding:utf-8
L1=[{"姓名":"Ming Wu","语文":90,"数学":91,"英语":93,"总评":0},
{"姓名":"John Doe","语文":67,"数学":78,"英语":86,"总评":0},
{"姓名":"Bob Smith","语文":43,"数学":95,"英语":75,"总评":0},
{"姓名":"Alan Doe","语文":0,"数学":47,"英语":97,"总评":0}
]
print(sorted(L1,key=lambda s:s["姓名"])) #L1的元素给 s,按字典的“姓名”排序
print()
print(sorted(L1,key=lambda s:s["姓名"].split()[1]))
print()
print(sorted(L1,key=lambda s:s["数学"]))
print()
for i in range(len(L1)):
a=L1[i]
a["总评"]=0.4*a["语文"]+0.4*a["数学"]+0.2*a["英语"]
print(L1)
print()
print(sorted(L1,key=lambda s:s["总评"],reverse=True))
###
[{'姓名': 'Alan Doe', '语文': 0, '数学': 47, '英语': 97, '总评': 0}, {'姓名': 'Bob Smith', '语文': 43, '数学': 95, '英语': 75, '总评': 0}, {'姓名': 'John Doe', '语文': 67, '数学': 78, '英语': 86, '总评': 0}, {'姓名': 'Ming Wu', '语文': 90, '数学': 91, '英语': 93, '总评': 0}]
[{'姓名': 'John Doe', '语文': 67, '数学': 78, '英语': 86, '总评': 0}, {'姓名': 'Alan Doe', '语文': 0, '数学': 47, '英语': 97, '总评': 0}, {'姓名': 'Bob Smith', '语文': 43, '数学': 95, '英语': 75, '总评': 0}, {'姓名': 'Ming Wu', '语文': 90, '数学': 91, '英语': 93, '总评': 0}]
[{'姓名': 'Alan Doe', '语文': 0, '数学': 47, '英语': 97, '总评': 0}, {'姓名': 'John Doe', '语文': 67, '数学': 78, '英语': 86, '总评': 0}, {'姓名': 'Ming Wu', '语文': 90, '数学': 91, '英语': 93, '总评': 0}, {'姓名': 'Bob Smith', '语文': 43, '数学': 95, '英语': 75, '总评': 0}]
[{'姓名': 'Ming Wu', '语文': 90, '数学': 91, '英语': 93, '总评': 91.0}, {'姓名': 'John Doe', '语文': 67, '数学': 78, '英语': 86, '总评': 75.2}, {'姓名': 'Bob Smith', '语文': 43, '数学': 95, '英语': 75, '总评': 70.2}, {'姓名': 'Alan Doe', '语文': 0, '数学': 47, '英语': 97, '总评': 38.2}]
[{'姓名': 'Ming Wu', '语文': 90, '数学': 91, '英语': 93, '总评': 91.0}, {'姓名': 'John Doe', '语文': 67, '数学': 78, '英语': 86, '总评': 75.2}, {'姓名': 'Bob Smith', '语文': 43, '数学': 95, '英语': 75, '总评': 70.2}, {'姓名': 'Alan Doe', '语文': 0, '数学': 47, '英语': 97, '总评': 38.2}]
参考资料
菜鸟教程 https://www.runoob.com/python3/python3-list.html
C语言中文网 http://c.biancheng.net/view/2209.html