बिल्ड एक सूची समझ के साथ एक नई सूची:
new_items = [x if x % 2 else None for x in items]
आप मूल सूची में जगह अगर आप चाहते हैं संशोधित कर सकते हैं, लेकिन यह वास्तव में समय की बचत नहीं करता है:
items = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
for index, item in enumerate(items):
if not (item % 2):
items[index] = None
यहां (पायथन 3.6.3) गैर-टाइम्सव का प्रदर्शन करने वाले समय हैं:
In [1]: %%timeit
...: items = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
...: for index, item in enumerate(items):
...: if not (item % 2):
...: items[index] = None
...:
1.06 µs ± 33.7 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
In [2]: %%timeit
...: items = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
...: new_items = [x if x % 2 else None for x in items]
...:
891 ns ± 13.6 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
और अजगर 2.7.6 समय:
In [1]: %%timeit
...: items = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
...: for index, item in enumerate(items):
...: if not (item % 2):
...: items[index] = None
...:
1000000 loops, best of 3: 1.27 µs per loop
In [2]: %%timeit
...: items = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
...: new_items = [x if x % 2 else None for x in items]
...:
1000000 loops, best of 3: 1.14 µs per loop
itertools मॉड्यूल का उपयोग करें, यह सबसे कुशल है। – LtWorf
'इन-प्लेस' प्रतिस्थापन तुलना के लिए, इस पर एक नज़र डालें [उत्तर] (http://stackoverflow.com/a/24203748/307454) – lifebalance