内容简介:这篇文章主要介绍了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程序设计有所帮助。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
大型网站系统与Java中间件开发实践
曾宪杰 / 电子工业出版社 / 2014-4-24 / 65.00
本书围绕大型网站和支撑大型网站架构的 Java 中间件的实践展开介绍。从分布式系统的知识切入,让读者对分布式系统有基本的了解;然后介绍大型网站随着数据量、访问量增长而发生的架构变迁;接着讲述构建 Java 中间件的相关知识;之后的几章都是根据笔者的经验来介绍支撑大型网站架构的 Java 中间件系统的设计和实践。希望读者通过本书可以了解大型网站架构变迁过程中的较为通用的问题和解法,并了解构建支撑大型......一起来看看 《大型网站系统与Java中间件开发实践》 这本书的介绍吧!