自然排序:排列嵌入数字的字符串的艺术
用数字对字符串进行排序可能是一项棘手的任务,但这对于许多人来说是必不可少的应用程序。在本次问答中,我们将探索一种实现类似人类排序结果的解决方案,允许您按逻辑顺序排列“something1”、“something2”和“something17”等字符串。
挑战:
给定的输入由包含数字的字符串列表组成。然而,默认的 sort() 方法无法以对人类有意义的方式排列它们。例如,以下列表:
something1 something12 something17 something2 something25 something29
将排序为:
something1 something12 something17 something2 something25 something29
解决方案:自然键
解决方案在于使用自然键,这是一种为人类可读性而设计的排序方法。自然键将字符串中的数字视为单独的实体,同时保持字符串的整体结构。
这是使用natural_keys函数的Python实现:
import re def natural_keys(text): return [int(c) if c.isdigit() else c for c in re.split(r'(\d+)', text)]
当应用于输入列表时,结果将是:
['something1', 'something2', 'something12', 'something17', 'something25', 'something29']
附加注意事项:
如果需要对浮点数的字符串进行排序,可以修改natural_keys函数中的正则表达式以匹配浮点数而不是整数。
def natural_keys(text): return [float(c) if c.isdigit() or '.' in c else c for c in re.split(r'[+-]?([0-9]+(?:[.][0-9]*)?|[.][0-9]+)', text)]
此增强功能使您能够对字符串进行排序,例如:
something1 something2 something1.0 something1.25 something1.105
,如下所示顺序:
['something1', 'something1.0', 'something1.105', 'something1.25', 'something2']
通过利用自然键的强大功能,您现在可以轻松地以人类可读的方式排列嵌入数字的字符串,使您的数据操作任务更加高效和直观。
以上是如何在 Python 中自然地对嵌入数字的字符串进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!