我有一个这样的字符串列表:
mylist = ["superduperlongstring", "a short string", "the middle"]
我想以这样的方式排序,即单词数最多的字符串排在第一位,即
mylist = ["a short string", "the middle", "superduperlongstring"]
这有点棘手,因为如果我按长度就地排序
mylist.sort(key = len)
我又回到了起点。
有没有人遇到过一个优雅的解决方案?谢谢。
最佳答案
假设单词由空格分隔,调用str.split
不带参数返回字符串包含的单词列表:
>>> "superduperlongstring".split()
['superduperlongstring']
>>> "a short string".split()
['a', 'short', 'string']
>>> "the middle".split()
['the', 'middle']
>>>
因此,您可以通过根据这些列表的长度对 mylist
进行排序来获得所需的输出:
>>> mylist = ["superduperlongstring", "a short string", "the middle"]
>>> mylist.sort(key=lambda x: len(x.split()), reverse=True)
>>> mylist
['a short string', 'the middle', 'superduperlongstring']
>>>
您还需要将 list.sort
的 reverse
参数设置为 True
,如上所示。
关于python - 按字符串中单词的数量对字符串列表进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24128380/