如何在Python中迭代排序的iterable
假设s是一个iterable,其中每个子元素不一定排序。通常我会这样做如何在Python中迭代排序的iterable,python,Python,假设s是一个iterable,其中每个子元素不一定排序。通常我会这样做 for element in S: element=sorted(element) ... 有没有办法做类似的事情 for sorted(element) in S: ... 您可以使用genexp,但您的原始代码已经足够好了: for element in (sorted(x) for x in S): # do things 另一种使用较少代码的方法是map: for element
for element in S:
element=sorted(element)
...
有没有办法做类似的事情
for sorted(element) in S:
...
您可以使用genexp,但您的原始代码已经足够好了:
for element in (sorted(x) for x in S):
# do things
另一种使用较少代码的方法是map
:
for element in map(sorted, S):
# or itertools.imap on Python2.x if you need iterators...
您可以使用genexp,但您的原始代码已经足够好了:
for element in (sorted(x) for x in S):
# do things
另一种使用较少代码的方法是map
:
for element in map(sorted, S):
# or itertools.imap on Python2.x if you need iterators...
如果您试图返回列表,可以执行列表理解
[sorted(element) for element in S]
如果您试图返回列表,可以执行列表理解
[sorted(element) for element in S]
所以你的问题是什么?你试过自己的代码吗?所以。。。你的问题是什么?你试过自己的代码吗?我认为这是最好的选择,尽管问题中的显式版本可能更清楚。我唯一的建议是避免混淆,不要在语句的不同部分重复使用相同的名称
元素
。我认为这是最好的选择,尽管问题中的明确版本可能更清楚。我唯一的建议是避免混淆,不要在语句的不同部分重复使用相同的名称元素
。