python列表(list)的使⽤技巧及⾼级操作
python列表(list)的使⽤技巧及⾼级操作
置顶 2018年03⽉25⽇ 13:39:41 顽劣的⽯头阅读数:5478 标签: python extend bisect list enumerate 更多
个⼈分类: python数据分析 Python
版权声明:本⽂为博主原创⽂章,未经博主允许不得转载。 blog.csdn/shaxiaozilove/article/details/79685168
1、合并列表(extend)
跟元组⼀样,⽤加号(+)将两个列表加起来即可实现合并:
In [1]: x=list(range(1, 13, 2))
In [2]: x + ['b', 'a']
Out[2]: [1, 3, 5, 7, 9, 11, 'b', 'a']
对于已定义的列表,可以⽤extend⽅法⼀次性添加多个元素:
In [7]: x2=[3, 6, 1]
In [8]: x.extend(x2)
In [9]: x
Out[9]: [1, 3, 5, 7, 9, 11, 3, 6, 1, 3, 6, 1, 3, 6, 1]
需要说明的是:加号(+)执⾏列表的合并是⾮常浪费资源的,因为必须创建⼀个新列表并将所有对象复制过去,⽽⽤extend将元素附加到现有列表(尤其是在构建⼀个⼤列表时)就会好很多。
因此,在进⾏列表合并操作时,尤其是对于⼤数据量的列表合并,强烈建议使⽤extend函数。
2、列表排序(sort)
列表的sort⽅法可以实现就地排序(⽆需创建新对象,字符串按⾸字母进⾏排序):
In [10]: a=[1, 5, 3, -3, 0]
In [11]: a.sort()
In [12]: a
Out[12]: [-3, 0, 1, 3, 5]
In [13]: s=['a','ab','3e','z']
In [14]: s.sort()
In [15]: s
Out[15]: ['3e', 'a', 'ab', 'z']
sort有⼏个很好⽤的选项,⼀个是次要排序键,即⼀个能够产⽣可⽤于排序的值的函数。如可以通过长度对⼀组字符串进⾏排序:
In [16]: b=['a','nl','drz','mowgt','aa']
In [17]: b.sort(key=len)
In [18]: b
Out[18]: ['a', 'nl', 'aa', 'drz', 'mowgt']
再⽐如是否进⾏降序排列,如下⾯通过对⾸字母进⾏降序排列的⽰例:
In [21]: b.sort(key= lambda x:x[0], reverse=True)
In [22]: b
Out[22]: ['nl', 'mowgt', 'drz', 'a', 'aa']
3、⼆分搜索及维护有序列表(bisect)
内置的bisect模块实现了⼆分查以及对有序列表的插⼊操作。bisect.bisect可以出新元素应该被插⼊到哪个位置以保持元列表的有序性,bisect.insort则将新元素插⼊到那个正确的位置上。
In [23]: import bisect
In [24]: c=[1,2,1,-1,4,5]
In [25]: c.sort()
In [26]: bisect.bisect(c, 2)
Out[26]: 4
In [27]: bisect.insort(c, 4)
In [28]: c
Out[28]: [-1, 1, 1, 2, 4, 4, 5]
注意:bisect模块的函数不会判断原列表是否有序,因为这样做开销太⼤;因此将他们⽤作⽆序列表时虽然不会出错,但可能会导致不正确的结果。基于此,建议在使⽤bisect模块的函数前,先对原列表执⾏排序的操作。
3、切⽚(索引运算符[]及start:stop)
可以对序列类型(数组、列表、元组等)进⾏切⽚操作,start索引处元素被包括在切⽚的结果中,stop索引处的元素未被包括在结果中,元素数量为 stop-start。start或stop都是可以省略的,此时他们分别默认为序列的起始处和结尾处。
还可以在第⼆个冒号后加上步长(step),⽐如每隔⼀位取⼀个元素:
In [35]: d=[x for x in range(10)]
In [36]: d
Out[36]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
In [37]: e=d[:8:2]
In [38]: e
Out[38]: [0, 2, 4, 6]
可以巧妙的使⽤ -1 ,实现对列表或元素的反序,如下:
In [40]: f=d[::-1]
In [41]: f
Out[41]: [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
4、列表内置的序列函数
4.1 enumerate
enumerate函数可以逐个返回序列的(i, value)元组,如下⽰例:
In [43]: #for i value in enumerate(collection):
In [44]: #⽤ i, value 做⼀些事情
In [49]: slist=['qin', 'wang', 'wqc']
In [50]: mapping = dict((v, i) for i, v in enumerate(list))
In [51]: mapping
Out[51]: {'qin': 0, 'wang': 1, 'wqc': 2}
4.2 sorted
sorted函数可以将任何序列返回为⼀个新的有序列表(注意:sort函数是就地排序),如下:
In [59]: sorted(['z', 'd', 'c', 'n'])
Out[59]: ['c', 'd', 'n', 'z']
In [60]: sorted('my name is chaogo')
Out[60]:
[' ',
' ',
' ',
'a',
'a',
'c',
'e',
'g',
'h',
'i',
'm',
'm',
'n',
'o',
'o',
's',
'y']
常常将sorted和set结合起来使⽤以得到⼀个由序列中的唯⼀元素构成的有序列表:
In [61]: set(sorted('my name is chaogo'))
Out[61]: {' ', 'a', 'c', 'e', 'g', 'h', 'i', 'm', 'n', 'o', 's', 'y'}
In [62]: sorted(set('my name is chaogo'))
Out[62]: [' ', 'a', 'c', 'e', 'g', 'h', 'i', 'm', 'n', 'o', 's', 'y']
In [63]: set('my name is chaogo')
Out[63]: {' ', 'a', 'c', 'e', 'g', 'h', 'i', 'm', 'n', 'o', 's', 'y'}
上⾯的结果都是⼀样的,什么原因呢?这是因为:(1)set和sorted是对序列进⾏操作,当参数不是序列时,会默认转换为列表;(2)set 默认会对元素进⾏排序。
4.3 zip
zip⽤于将多个序列(列表、元组等)中的元素“配对”,从⽽产⽣⼀个新的元组列表;zip可以接受任意数量的序列,最终得到的元组数量由最短的序列决定;zip最常见的⽤法是同时迭代多个序列,还可以结合enumerate⼀起使⽤,如下:
In [77]: seq1 = ['chao', 'qing', 'wq']
In [78]: seq2 = ['qin', 'wang', 'qc']
In [79]: for i , (a,b) in enumerate(zip(seq1, seq2)):
.
..: print('%d: %s %s' % (i, a, b))
...:
0: chao qin
1: qing wang
2: wq qc
对于“已压缩的”(zipped)序列,zip还有⼀个很巧妙的⽤法,即对该序列进⾏解压(unzip,⽤*表⽰)。其实就是将⼀组⾏转换为⼀组列,如下:
In [86]: pitchers = [('a','b'), (1,2), ('tmd','bat')]
In [87]: one, two = zip(*pitchers)
In [88]: one
Out[88]: ('a', 1, 'tmd')
In [89]: two
python 定义数组Out[89]: ('b', 2, 'bat')
4.4 reversed
⽤于按逆序迭代序列中的元素,如下:
In [92]: [x for x in reversed([1, 2, 5, 3, -1])]
Out[92]: [-1, 3, 5, 2, 1]
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论