Chr*_*ini 9 ruby arrays sorting natural-sort
我试图用一个int和字符串的混合排序一个数组.举个例子:
a = ["a", "b", 5, "c", 4, "d", "a1", "a12", 3, 13, 2, "13a", "12a"]
Run Code Online (Sandbox Code Playgroud)
我试过了:
a.sort do |x, y|
if x.class == y.class
x <=> y
else
x.class.to_s <=> y.class.to_s
end
end
Run Code Online (Sandbox Code Playgroud)
哪个回报:
[2, 3, 4, 5, 13, "12a", "13a", "a", "a1", "a12", "b", "c", "d"]
Run Code Online (Sandbox Code Playgroud)
我想要的结果是:
[2, 3, 4, 5, "12a", 13, "13a", "a", "a1", "a12", "b", "c", "d"]
Run Code Online (Sandbox Code Playgroud)
ndn*_*kov 11
a.sort_by { |x| [(x.to_s.match(/^\d+/) ? x.to_i : 1.0 / 0), x.to_s] }
Run Code Online (Sandbox Code Playgroud)
我们的想法是首先按数值排序,然后按字符串值排序.如果字符串不以数字值开头,则强制将数值视为无穷大.
编辑:由于OP已经明确表示他不仅要考虑前导数值,而是考虑所有后面的数值,我们可以使用相同的想法,这次我们必须将它应用于字符串中的每个单独的数字和非数字实体:
a.sort_by do |x|
x.to_s.split(/(\D+)/).map do |y|
[(y.match(/\d/) ? y.to_i : 1.0 / 0), y]
end
end
Run Code Online (Sandbox Code Playgroud)