4

アイテムのリスト(Beautiful Soupで抽出されたHTMLテーブル行)があり、リストを反復処理して、ループの実行ごとに偶数要素と奇数要素(つまりインデックス)を取得する必要があります。私のコードは次のようになります。

for top, bottom in izip(table[::2], table[1::2]):
    #do something with top
    #do something else with bottom

このコードを醜くする方法は?それとも、これを行うのに良い方法ですか?

編集:

table[1::2], table[::2]  => table[::2], table[1::2]
4

3 に答える 3

5

izipこれはかなり良いオプションですが、不満があるため、いくつかの選択肢があります。

>>> def chunker(seq, size):
...     return (tuple(seq[pos:pos+size]) for pos in xrange(0, len(seq), size))
...
>>> x = range(11)
>>> x
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> chunker(x, 2)
<generator object <genexpr> at 0x00B44328>
>>> list(chunker(x, 2))
[(0, 1), (2, 3), (4, 5), (6, 7), (8, 9), (10,)]
>>> list(izip(x[1::2], x[::2]))
[(1, 0), (3, 2), (5, 4), (7, 6), (9, 8)]

ご覧のとおり、これには不均一な量の要素を適切に処理できるという利点があります。これは、重要な場合と重要でない場合があります。itertoolsドキュメント自体からのこのレシピもあります:

>>> def grouper(n, iterable, fillvalue=None):
...     "grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx"
...     args = [iter(iterable)] * n
...     return izip_longest(fillvalue=fillvalue, *args)
...
>>>
>>> from itertools import izip_longest
>>> list(grouper(2, x))
[(0, 1), (2, 3), (4, 5), (6, 7), (8, 9), (10, None)]
于 2009-06-10T08:04:56.877 に答える
4

試す:

def alternate(i):
    i = iter(i)
    while True:
        yield(i.next(), i.next())

>>> list(alternate(range(10)))
[(0, 1), (2, 3), (4, 5), (6, 7), (8, 9)]

このソリューションは、リストだけでなく、任意のシーケンスで機能し、シーケンスをコピーしません(長いシーケンスの最初のいくつかの要素のみが必要な場合は、はるかに効率的です)。

于 2009-06-10T09:33:42.033 に答える
0

いいね。私の唯一の提案は、これを関数またはメソッドでラップすることです。そうすれば、名前(evenOddIter())を付けて、読みやすくすることができます。

于 2009-06-10T08:04:39.063 に答える