为了账号安全,请及时绑定邮箱和手机立即绑定

排序混合的字母/数字数组

排序混合的字母/数字数组

波斯汪 2019-10-11 09:58:13
我有一个混合数组,我需要先按字母然后按数字排序[A1, A10, A11, A12, A2, A3, A4, B10, B2, F1, F12, F3]我如何将其排序为:[A1, A2, A3, A4, A10, A11, A12, B2, B10, F1, F3, F12]我努力了arr.sort(function(a,b) {return a - b});但这只是按字母顺序排序。可以使用直接的JavaScript或jQuery完成此操作吗?
查看完整描述

3 回答

?
互换的青春

TA贡献1797条经验 获得超6个赞

var reA = /[^a-zA-Z]/g;

var reN = /[^0-9]/g;


function sortAlphaNum(a, b) {

  var aA = a.replace(reA, "");

  var bA = b.replace(reA, "");

  if (aA === bA) {

    var aN = parseInt(a.replace(reN, ""), 10);

    var bN = parseInt(b.replace(reN, ""), 10);

    return aN === bN ? 0 : aN > bN ? 1 : -1;

  } else {

    return aA > bA ? 1 : -1;

  }

}

console.log(

["A1", "A10", "A11", "A12", "A2", "A3", "A4", "B10", "B2", "F1", "F12", "F3"].sort(sortAlphaNum)

)


查看完整回答
1 反对 回复 2019-10-11
?
HUWWW

TA贡献1874条经验 获得超12个赞

const sortAlphaNum = (a, b) => a.localeCompare(b, 'en', { numeric: true })`

用法:


const sortAlphaNum = (a, b) => a.localeCompare(b, 'en', { numeric: true })

console.log(['A1', 'A10', 'A11', 'A12', 'A2', 'A3', 'A4', 'B10', 'B2', 'F1', 'F12', 'F3'].sort(sortAlphaNum))

给出:


["A1", "A2", "A3", "A4", "A10", "A11", "A12", "B2", "B10", "F1", "F3", "F12"]


您可能必须将'en'参数更改为您的语言环境或以编程方式确定,但这适用于英语字符串。


同样localeCompare也不受超级一致的支持,但是如果您使用babel进行转译不会有问题


查看完整回答
反对 回复 2019-10-11
?
Qyouu

TA贡献1786条经验 获得超11个赞

我也遇到类似的情况,但是混合使用字母数字和数字,因此需要先对所有数字进行排序,然后再对字母数字进行排序,因此:


A10

1

5

A9

2

B3

A2

需要成为:


1

2

5

A2

A9

A10

B3

我能够使用提供的算法并对它进行更多修改以实现此目的:


var reA = /[^a-zA-Z]/g;

var reN = /[^0-9]/g;

function sortAlphaNum(a,b) {

    var AInt = parseInt(a, 10);

    var BInt = parseInt(b, 10);


    if(isNaN(AInt) && isNaN(BInt)){

        var aA = a.replace(reA, "");

        var bA = b.replace(reA, "");

        if(aA === bA) {

            var aN = parseInt(a.replace(reN, ""), 10);

            var bN = parseInt(b.replace(reN, ""), 10);

            return aN === bN ? 0 : aN > bN ? 1 : -1;

        } else {

            return aA > bA ? 1 : -1;

        }

    }else if(isNaN(AInt)){//A is not an Int

        return 1;//to make alphanumeric sort first return -1 here

    }else if(isNaN(BInt)){//B is not an Int

        return -1;//to make alphanumeric sort first return 1 here

    }else{

        return AInt > BInt ? 1 : -1;

    }

}

var newlist = ["A1", 1, "A10", "A11", "A12", 5, 3, 10, 2, "A2", "A3", "A4", "B10", "B2", "F1", "F12", "F3"].sort(sortAlphaNum);


查看完整回答
反对 回复 2019-10-11
  • 3 回答
  • 0 关注
  • 569 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信