python列表(list)的技巧及高级操作

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
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]

原文地址:https://www.cnblogs.com/originalTblog/p/11745134.html

时间: 2024-11-05 17:24:29

python列表(list)的技巧及高级操作的相关文章

python列表(list)的使用技巧及高级操作

python列表(list)的使用技巧及高级操作置顶 2018年03月25日 13:39:41 顽劣的石头 阅读数:5478 标签: python extend bisect list enumerate 更多个人分类: python数据分析 Python版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/shaxiaozilove/article/details/79685168 1.合并列表(extend) 跟元组一样,用加号(+)将两个列表加起

python列表、字典、字符串常用操作

Python 列表.字典.字符串常用操作 1.字符串操作 字符串可以通过下标取值,但由于字符串是不可变变量,不可通过下标来修改值. str = 'lily terry mark' name[0]    #获取第1个字符串值 name[0:7]   #获取第1~7的字符串值 name[:7]   #缺省开始位置,默认从第1个元素开始取值 name[0:]   #缺省结束位置,默认到字符串末尾结束 字符串包含判断操作符:in .not in .is 'lily' in names 'lily' no

Python列表(list)所有元素的同一操作

针对很普遍的每个元素的操作会遍历每个元素进行操作. 这里给出了几种写法,列表每个元素自增等数学操作同理: 示例:整形列表ilist加1个数.元素类型转字符串: 1 ilist = [1, 2, 3, 10, 11, 12] 2 3 4 # 每个元素加5,四种方法 5 for i, v in enumerate(ilist): ilist[i] = v + 5 6 [ x+5 for x in ilist ] 7 map(lambda x:x+5, ilist) # 仅python 2 8 lis

python列表分组的技巧

今天项目上需要到的. 如,将并行部署的机器分批次. 一次十台机器,如果分3次并行部署,则第一次123,第二次456,第三次789,第四次10. #coding=utf-8 a=[1,2,3,4,5,6,7,8,9,10] b = [a[i:i+3] for i in xrange(0,len(a),3)] print b

Python 列表(list)操作

创建列表 sample_list = ['a',1,('a','b')] Python 列表操作 sample_list = ['a','b',0,1,3] 得到列表中的某一个值 value_start = sample_list[0] end_value = sample_list[-1] 删除列表的第一个值 del sample_list[0] 在列表中插入一个值 sample_list[0:0] = ['sample value'] 得到列表的长度 list_length = len(sa

Python列表list 数组array常用操作集锦【转】

Python中的列表(list)类似于C#中的可变数组(ArrayList),用于顺序存储结构. 创建列表 sample_list = ['a',1,('a','b')] Python 列表操作 sample_list = ['a','b',0,1,3] 得到列表中的某一个值 value_start = sample_list[0] end_value = sample_list[-1] 删除列表的第一个值 del sample_list[0] 在列表中插入一个值 sample_list[0:0

Python 变量之列表与应用技巧

洛琳的笔记 Python 标准数据类型 Python 定义了一些标准数据类型,用于存储各种类型的数据.Python有五个标准的数据类型,分别是: Numbers(数字) String(字符串) List(列表) Tuple(元组) Dictionary(字典) Python 中的变量赋值不需要类型声明,也就是说声明变量不需要使用关键字.Python 中变量赋值之后该变量就被创建.可以简单对单一变量赋值,亦可对同一变量重新赋值(不同数据类型也可以),也可以同时为多个变量赋值,如下. counter

python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。

本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding:utf-8from com.wenhy.crawler_baidu_baike import url_manager, html_downloader, html_parser, html_outputer print "爬虫百度百科调度入口" # 创建爬虫类class SpiderMai

python列表基础操作

Python列表基本操作 记住一句话,叫做顾首不顾尾 首先我们来定义一个列表 name = ["jixuege","dajiba","boduoye","cangjinkong","youtianai"] 接下来,我们就对这个列表来进行一系列的操作 1.切片 取值,取第一个和第二个 print(name[0],name[1]) 打印结果 jixuege dajiba 说明: 上面的0和1指的是小标,从左到右