共计 4610 个字符,预计需要花费 12 分钟才能阅读完成。
开启变身模式
大家好, 从这一期开始,我们会从小白变身为中等小白,在基础起步阶段有太多的东西我没有讲到,但是俗话说的好,无他,但手熟尔,只要多多练习,时间会是最好的证明,相信我们终有一天会成为高手,因此从这一系列开始,让我们一起更上一层楼,还是和往常一样,我也是水平不高,如果有大神发现文章中的错误一定要指出哈~
先皮一下,看个欧阳修的 << 卖油翁 >>:
陈康肃公尧咨善射,当世无双,公亦以此自矜。尝射于家圃,有卖油翁释担而立,睨之,久而不去。见其发矢十中八九,但微颔之。康肃问曰:“汝亦知射乎?吾射不亦精乎?”翁曰:“无他,但手熟尔。”康肃忿然曰:“尔安敢轻吾射!”翁曰:“以我酌油知之。”乃取一葫芦置于地,以钱覆其口,徐以杓酌油沥之,自钱孔入,而钱不湿。因曰:“我亦无他,惟手熟尔。”康肃笑而遣之。
List 的进阶用法
这里我将会详细介绍一些我认为非常不错的 List 的使用方法,至于 list 自带的一些基础用法,这里不再说明,感兴趣的朋友们可以看看我的基础教程: Python 基础起步 (五) 一定要知道的数据类型:初识 List 和 Python 基础起步 (六) List 的实用技巧大全, 好啦,闲话少说,让我们开始吧
把其他类型数据结构转化为 List 类型
利用 list(target) 即可实现把其他类型的数据结构转化为 List 类型,十分实用,我们可以把字符串,元组等数据结构转化为 List, 也可以直接创建, 像下图一样:
print(list()) # 创建空 List
vowelString = ‘aeiou’ # 把字符串转化为 List
print(list(vowelString))
vowelTuple = (‘a’, ‘e’, ‘i’, ‘o’, ‘u’) # 从元组 tuple 转化为 List
print(list(vowelTuple))
vowelList = [‘a’, ‘e’, ‘i’, ‘o’, ‘u’] # 从 List 到 List
print(list(vowelList))
vowelSet = {‘a’, ‘e’, ‘i’, ‘o’, ‘u’} # 从 Set 到 List
print(list(vowelSet))
Out: []
[‘a’, ‘e’, ‘i’, ‘o’, ‘u’]
[‘a’, ‘e’, ‘i’, ‘o’, ‘u’]
[‘a’, ‘e’, ‘i’, ‘o’, ‘u’]
[‘a’, ‘e’, ‘i’, ‘o’, ‘u’]
可能平时用的比较多的一般是从一个 dict 中提取 keys 和 values:
person = {
‘name’:’Peppa Pig’,
‘age’:15,
‘country’:’bratian’}
person_keys = list(person.keys())
person_values = list(person.values())
print(list(person)) # 如果直接转化一个字典只会把 keys 提取出来
print(list(person.keys()))
print(list(person.values()))
Out:[‘name’, ‘age’, ‘country’]
[‘name’, ‘age’, ‘country’] # 把字典中的 Keys 提出
[‘Peppa Pig’, 15, ‘bratian’] # 把字典中的 Values 提出
这里大家稍微注意下,如果直接用 list(person) 会默认等同于 person.keys()
List 排序方法汇总
总体来说,有两种方法最为便捷,List.sort 或者 sorted(List), 具体来看如何实现,先看升序:
vowels = [‘e’, ‘a’, ‘u’, ‘o’, ‘i’]
vowels.sort()
print(‘Sorted list Acending:’, vowels) # 使用 sort
Out: Sorted list Acending: [‘a’, ‘e’, ‘i’, ‘o’, ‘u’]
vowels = [‘e’, ‘a’, ‘u’, ‘o’, ‘i’]
print(‘Sorted list Acending:’, sorted(vowels)) # 使用 sorted
Out:Sorted list Acending: [‘a’, ‘e’, ‘i’, ‘o’, ‘u’]
再来看降序:
vowels = [‘e’, ‘a’, ‘u’, ‘o’, ‘i’]
vowels.sort(reverse=True) # 使用 sort
print(‘Sorted list (in Descending):’, vowels)
Out: Sorted list (in Descending): [‘u’, ‘o’, ‘i’, ‘e’, ‘a’]
vowels = [‘e’, ‘a’, ‘u’, ‘o’, ‘i’]
print(‘Sorted list (in Descending):’, sorted(vowels,reverse=True)) # 使用 sorted 方法
Out:Sorted list (in Descending): [‘u’, ‘o’, ‘i’, ‘e’, ‘a’]
其实这里里面还有一个关键的参数是 key,我们可以自定义一些规则排序,下面看个例子,用的是默认的 len 函数,让我们根据 List 中每个元素的长度来排序,首先是升序:
vowels = [‘I’, ‘live’, ‘at’, ‘Paris’, ‘I’,’love’,’Python’]
# 使用 sort
vowels.sort(key=len)
print(‘Sorted by lenth Ascending:’, vowels)
Out:Sorted by lenth: [‘I’, ‘I’, ‘at’, ‘live’, ‘love’, ‘Paris’, ‘Python’]
vowels = [‘I’, ‘live’, ‘at’, ‘Paris’, ‘I’,’love’,’Python’]
# 使用 sorted
print(‘Sorted by lenth Ascending:’, sorted(vowels,key=len))
Out:Sorted by lenth Ascending: [‘I’, ‘I’, ‘at’, ‘live’, ‘love’, ‘Paris’, ‘Python’]
降序也差不多啦:
vowels = [‘I’, ‘live’, ‘at’, ‘Paris’, ‘I’,’love’,’Python’]
vowels.sort(key=len,reverse=True)
print(‘Sorted by lenth Descending:’, vowels)
Out:Sorted by lenth Descending: [‘Python’, ‘Paris’, ‘live’, ‘love’, ‘at’, ‘I’, ‘I’]
vowels = [‘I’, ‘live’, ‘at’, ‘Paris’, ‘I’,’love’,’Python’]
print(‘Sorted by lenth Descending:’, sorted(vowels,reverse=True))
Out:Sorted by lenth Descending: [‘Python’, ‘Paris’, ‘live’, ‘love’, ‘at’, ‘I’, ‘I’]
有关这个 key 我们可以自己定义,请看下面的大栗子:
def takeSecond(elem):
return elem[1]
random = [(2, 2), (3, 4), (4, 1), (1, 3)]
random.sort(key=takeSecond) # sort list with key
print(‘Sorted list:’, random)
Out:[(4, 1), (2, 2), (1, 3), (3, 4)]
这里因为列表中的元素都是元组,所以我们规定按照元组的第二个数排序,所以结果如上,默认依然是 reverse=Fause,也就是升序,至于其他有意思的方法大家可以自己开发
利用 Range 生成 List
Python 里面为我们提供了一个超好用的方法 range(),具体的用法很多,不在这里一一讲解啦,但是大家可以看一下它如何和 List 结合在一起的:
five_numbers=list(range(5)) #创建 0~4 的 List
print(five_numbers)
odd_numbers=list(range(1,50,2)) #创建 0~50 所有的奇数的 List
print(odd_numbers)
even_numbers=list(range(0,50,2)) #创建 0~50 所有的偶数的 List
print(even_numbers)
其实很简单,用的最多的就是 range(start, stop, hop) 这个结构,其他的大家可以自行查询哈
List 列表推导式
其实这个东西无非就是为了减少代码书写量,比较 Pythonic 的东西,基础模板如下:
variable = [out_exp for out_exp in input_list if out_exp == 2]
大家直接看比较麻烦,还是直接上代码吧:
S = [x**2 for x in range(8)] # 0~7 每个数的平方存为 List
V = [2**i for i in range(8)] # 2 的 0~7 次方
M = [x for x in S if x % 2 == 0] #找出在 S 里面的偶数
print(S)
print(V)
print(M)
Out: Square of 0 ~7: [0, 1, 4, 9, 16, 25, 36, 49]
The x power of 2,(0<x<7) : [1, 2, 4, 8, 16, 32, 64, 128]
The even numbers in S: [0, 4, 16, 36]
通过这个小栗子大家估计已经明白用法啦,推导式还可以这么用:
verbs=[‘work’,’eat’,’sleep’,’sit’]
verbs_with_ing=[v+’ing’ for v in verbs] # 使一组动词成为现在分词
print(verbs_with_ing)
Out:[‘working’, ‘eating’, ‘sleeping’, ‘siting’]
或者加上查询条件 if:
all_numbers=list(range(-7,9))
numbers_positive = [n for n in all_numbers if n>0]
numbers_negative = [n for n in all_numbers if n<0]
devided_by_two = [n for n in all_numbers if n%2==0]
print(“The positive numbers between -7 to 9 are :”,numbers_positive)
print(“The negative numbers between -7 to 9 are :”,numbers_negative)
print(“The numbers deveided by 2 without reminder are :”,devided_by_two)“`
Out:The positive numbers between -7 to 9 are : [1, 2, 3, 4, 5, 6, 7, 8]
The negative numbers between -7 to 9 are : [-7, -6, -5, -4, -3, -2, -1]
The numbers deveided by 2 without reminder are : [-6, -4, -2, 0, 2, 4, 6, 8]
总结
其实客观来讲,list 在实际项目中所用的地方有限,特别是处理数据量较大的情况下,因为速度极慢,但是在一些边边角角的地方我个人用的还挺多,尤其是不求速度的地方,总的来讲 List 是我个人比较喜欢的 Python 数据结构,简单好用!!!!!
好啦,我要去吃大餐啦,祝大家新年快乐呀!!!