内容简介:这篇文章主要介绍了Python使用zip合并相邻列表项的方法,涉及zip、iter函数合并相邻列表项、切片等相关操作技巧,需要的朋友可以参考下
本文实例讲述了 Python 使用zip合并相邻列表项的方法。分享给大家供大家参考,具体如下:
1》使用zip()
函数和iter()
函数,来合并相邻的列表项
>>> x [1, 2, 3, 4, 5, 6, 7, 8, 9] >>> zip(*[iter(x)]*2) [(1, 2), (3, 4), (5, 6), (7, 8)] >>> zip(*[iter(x)]*3) [(1, 2, 3), (4, 5, 6), (7, 8, 9)] >>> zip(*[iter(x)]*4) [(1, 2, 3, 4), (5, 6, 7, 8)]
之所以会出现上述结果,是因为:
>>> [iter(x)]*3 [<listiterator object at 0x02F4D790>, <listiterator object at0x02F4D790>, <listiterator object at 0x02F4D790>]
可以看到,列表中的3个迭代器实际上是同一个迭代器!!!
2》 在1》的基础上,封装成一个函数,如下:
>>> x [1, 2, 3, 4, 5, 6, 7, 8, 9] >>> group_adjacent = lambda a, k: zip(*([iter(a)] * k)) >>> group_adjacent(x,3) [(1, 2, 3), (4, 5, 6), (7, 8, 9)] >>> group_adjacent(x,2) [(1, 2), (3, 4), (5, 6), (7, 8)] >>> group_adjacent(x,1) [(1,), (2,), (3,), (4,), (5,), (6,), (7,), (8,), (9,)]
3》使用zip()
函数和切片操作,来合并相邻的表项
>>> x [1, 2, 3, 4, 5, 6, 7, 8, 9] >>> zip(x[::2],x[1::2]) [(1, 2), (3, 4), (5, 6), (7, 8)] >>> zip(x[0::2],x[1::2]) [(1, 2), (3, 4), (5, 6), (7, 8)] >>> zip(x[0::3],x[1::3],x[2::3]) [(1, 2, 3), (4, 5, 6), (7, 8, 9)] >>> zip(x[::3],x[1::3],x[2::3]) [(1, 2, 3), (4, 5, 6), (7, 8, 9)]
4》 在3》的基础上,封装成函数,如下:
>>> x [1, 2, 3, 4, 5, 6, 7, 8, 9] >>> group_adjacent = lambda a, k: zip(*[a[i::k] for i in range(k)]) >>> group_adjacent(x,3) [(1, 2, 3), (4, 5, 6), (7, 8, 9)] >>> group_adjacent(x,2) [(1, 2), (3, 4), (5, 6), (7, 8)] >>> group_adjacent(x,1) [(1,), (2,), (3,), (4,), (5,), (6,), (7,), (8,), (9,)]
参考文章:
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python函数使用技巧总结》、《Python数据结构与算法教程》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
SEM修炼手册:百度竞价、信息流广告、数据分析与专题页策划实战详解
陈丰洲 / 电子工业出版社 / 2018-10 / 59.80元
SEM人员在职场打拼的过程中,会遇到一个又一个坑,《SEM修炼手册:百度竞价、信息流广告、数据分析与专题页策划实战详解》尝试站在一定的高度,将从业者从专员走向管理岗位过程中可能碰到的问题进行整理,不仅谈竞价推广,也谈基于SEM的营销体系。 《SEM修炼手册:百度竞价、信息流广告、数据分析与专题页策划实战详解》包括11章内容,由浅入深地分享SEM的进阶过程。第1章是SEM概述,让读者对SEM有......一起来看看 《SEM修炼手册:百度竞价、信息流广告、数据分析与专题页策划实战详解》 这本书的介绍吧!