【发布时间】:2021-11-04 03:31:58
【问题描述】:
我有一个列表,其中最长的单词不是真正的英语单词,所以我想在列表中找到第二长的单词以确保它是一个英语单词。
words 是我列表的名称
我试过了
longest_word = max(words, key=len)-2
longest_word = max(words, key=len)[:-2]
我试过了
from itertools import groupby
[next(g) for _, g in groupby(sorted(longest_word, key=len), len][-2]
如何找到列表中第二长的单词?
【问题讨论】:
-
嗯,你试过
sorted(words, key=len)[-2]吗? -
似乎已经做到了。如果您希望将您的评论作为答案,我会将其标记为已接受的答案并对其进行投票@rv.kvetch
-
嗯,这是个好主意,不幸的是,它看起来已经关闭了。仍然是个好主意,并欣赏它:-)
-
欢迎来到 Stack Overflow。问题以重复的形式关闭,因为它可以帮助其他人稍后搜索该网站,并且可以节省其他回答者的工作量。我们并不是因为找不到重复项而责骂您 - 我们是为您找到它并为您提供链接,即回答您的问题。另外,请记住,如果您反对您的问题的处理方式,则该投诉不属于对问题的编辑 - 它属于评论或meta.stackoverflow.com。
-
在搜索时可以帮助的另一件事是概括一下。例如
python n longest给我another candidate 作为第一个结果,尽管这不是同一个问题。