Python之list

列表的元素的数据类型可以不一致。

[ ]。 创建一个列表,只要把逗号分隔的不同的数据项使用方括号括起来即可。如下所示:

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])
函数与方法
序号函数
1len(list) 列表元素个数
2max(list) 返回列表元素最大值
3min(list) 返回列表元素最小值
4list(seq) 将序列转换为列表

下表中的“list”换成实际的 列表名

序号方法
1list.append(obj) 在列表末尾添加新的对象
2list.count(obj) 统计某个元素在列表中出现的次数
3list.extend(seq) 在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
4list.index(obj) 从列表中找出某个值第一个匹配项的索引位置
5list.insert(index, obj) 将对象插入列表成为索引为 index 的元素
6list.pop(index=-1) 移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
7list.remove(obj) 移除列表中某个值的第一个匹配项
8list.reverse() 反向列表中元素,无返回值
9list.sort( key=None, reverse=False) 对原列表进行排序,无返回值
10list.clear() 清空列表
11list.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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值