假设我有一个如下所示的列表:
['item1', 'item2', 'item3', 'item4', 'item5', 'item6', 'item7', 'item8', 'item9', 'item10']
Run Code Online (Sandbox Code Playgroud)
使用Python,我如何从中获取对,其中每个项目都包含在一对与之前和之后的项目中?
['item1', 'item2']
['item2', 'item3']
['item3', 'item4']
['item4', 'item5']
['item5', 'item6']
['item6', 'item7']
['item7', 'item8']
['item8', 'item9']
['item9', 'item10']
Run Code Online (Sandbox Code Playgroud)
看起来像我可以破解的东西,但我想知道是否有人有一个他们以前使用过的优雅解决方案?
Sim*_*lan 11
一个快速简单的方法是这样的:
a = ['item1', 'item2', 'item3', 'item4', 'item5', 'item6', 'item7', 'item8', 'item9', 'item10']
print zip(a, a[1:])
Run Code Online (Sandbox Code Playgroud)
这会产生以下结果:
[('item1', 'item2'), ('item2', 'item3'), ('item3', 'item4'), ('item4', 'item5'), ('item5', 'item6'), ('item6', 'item7'), ('item7', 'item8'), ('item8', 'item9'), ('item9', 'item10')]
Run Code Online (Sandbox Code Playgroud)