上一篇文章我们学习了python里的元素和它的操作,这一篇文章详细介绍元素们的集合——列表及其操作。因为最近在学CTF里的Re,因此可能有时候时间会分配去re,有时也会写写wp,re方向的各位可以关注。
言归正传,这里的列表可以类比成c里的数组,但是却不尽相同,因为C里的数组严格地限制了元素类型,字符数组不能放入整型数据,数组也不能容纳字符型数据,但这里的列表则没有限定。你可以将许多不同类型的数据塞在一个列表里,如:
today=['father','20','dogs','$']
要我说,他更像是c里的结构体,包罗万物,富含面向对象的思想。
列表可以这样写:
cars=['bmw','honda','toyota']
print(cars)
打印的结果:
['bmw', 'honda', 'toyota']
假如你是汽车销售,你不可能将这一个列表全部丢给客户。我们要学习如何精准访问列表中的元素
print(cars[0])
加多一句这个,再看看结果:
ok,单独输出了!值得注意的是,索引的首值为0;
创建了列表,我们可能要对列表中的数据进行变动,这时候这些语句就会派上用场:
cars=['bmw','honda','toyota']
print(cars)
cars[0]="mini" #修改第一个元素
cars.append('BYD')#在列表尾部增加新元素
cars.insert(1,'XiaoPeng')#在列表第二个元素的位置插入新元素
del cars[3] #删除列表第四位元素
print(cars)
效果很好。
但我们del之后,我们就无法访问toyota了,万一我的情景是,将Toyota单独拉出来仔细考察(就是从列表“取出”然后访问),怎么办?
我们可以用到pop()方法,学过汇编或者对计算机栈有一定了解的同学就会清楚,pop和push正是栈里出栈和入栈的函数,pop()方法即起源于此,pop是弹出,是对元素物理空间的改变(从栈到寄存器待处理使用)而不是将这个元素废弃删除,pop和del有本质不同,虽然看起来都像是将该元素从列表中抹去一样。具体使用方法和之前的title()方法一样,都是:
cars=['bmw','honda','toyota']
print(cars)
cars[0]="mini" #修改第一个元素
cars.append('BYD')#在列表尾部增加新元素
cars.insert(1,'XiaoPeng')#在列表第二个元素的位置插入新元素
#del cars[3] #删除列表第四位元素#注释掉
print(cars)#打印弹出数据前的列表作比较
popped_car=cars.pop()#定义一个变量储存弹出的元素
print(cars)
print(popped_car)
值得注意的是,与栈的pop弹出一样,pop()方法遵循栈内数据先入后出的特点,弹出的总是且仅是栈顶/列表顶顶元素,请看结果:
当然,与栈不同的是,列表不同与真正的栈,pop()方法可以通过将位置坐标放在pop()的括号内实现精准弹出列表元素
cars=['bmw','honda','toyota']
cars[0]="mini" #修改第一个元素
cars.append('BYD')#在列表尾部增加新元素
cars.insert(1,'XiaoPeng')#在列表第二个元素的位置插入新元素\
print(cars)
#del cars[3] #删除列表第四位元素#注释掉
popped_car=cars.pop(2)#弹出位置为2的元素
print(cars)
print(popped_car)
result:
['mini', 'XiaoPeng', 'honda', 'toyota', 'BYD']
['mini', 'XiaoPeng', 'toyota', 'BYD']
honda
当一个列表是许许多多的有重复的数字,而你想删除特定值的元素却不知道数量和位置时,可以用remove(),如:
c=[3,5,2,6,8,4,6,3,8,4,6,1,9]
print(c)
c.remove(6)
print(c)
result:
[3, 5, 2, 6, 8, 4, 6, 3, 8, 4, 6, 1, 9]
[3, 5, 2, 8, 4, 6, 3, 8, 4, 6, 1, 9]
注意,remove只会去除特定值元素的第一个,若想去除所以,要通过循环实现。我们后文再述。