테스트 사이트 - 개발 중인 베타 버전입니다

자바스크립트 sort()를 이용한 숫자 정렬

· 18년 전 · 4150
자바스크립트에서 sort는 기본적으로 아스키값을 기준으로 정렬합니다.

그래서 2보다 10이 앞에 오죠.


숫자 정렬되게 sort용 함수를 만들어봤습니다.

# 음수는 -가 제일 앞에 와야 제대로 정렬합니다.
뒤에 붙으면 문자로서의 -와 기능적으로 구분하기가 거의 불가능하므로 그냥 문자 취급합니다.


function sort2(a,b)
{
    if(parseInt(a) > parseInt(b)) return 1;
    else if(parseInt(a) < parseInt(b)) return -1;
    else
    {
        var sort = new Array(a,b);
        sort.sort();
        return (sort[0] == a)?-1:1;
    }
}

간단하게 했지만, 문자 뒤에 오는 숫자는 역시 제대로 정렬되지 않습니다.

아래는 문자 뒤의 숫자도 정렬하게 만든 것.


function sort(a,b)
{
    aS = a.toString(10).toUpperCase();
    bS = b.toString(10).toUpperCase();
    if(aS == bS) return 0;

    while(aS || bS)
    {
        aS = aS.replace(/^((\-?\d*)[^\d]*)/,"");
        aT = RegExp.$1;
        aN = RegExp.$2;

        bS = bS.replace(/^((\-?\d*)[^\d]*)/,"");
        bT = RegExp.$1;
        bN = RegExp.$2;
    
        if(aN && bN && aN != bN) return Number(aN)>Number(bN)?1:-1;
        else if(aT != bT)
        {
            var sort = new Array(aT,bT);
            sort.sort();
            return (sort[0] == aT)?-1:1;
        }
    }
}

덧붙여서 대소문자 구분하지 않고 정렬합니다.
[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

게시글 목록

번호 제목
12537
29323
12536
12535
12534
12533
29322
12532
12531
12530
29321
12529
12528
12527
12526
29320
12525
12524
12523
29319
12522
12521
12520
12519
29318
12518
12517
12516
29315
25032
25030
25028
25027
25026
25024
25022
80
29314
12515
12514
12513
12512
29313
12511
12510
12509
12508
12506
25021
25019
25017
78
12505
29311
12504
12503
12502
12501
29310
12500
12499
12496
75
12495
12491
12489
73
12488
12487
71
12486
12479
29308
62
12476
12475
12474
12471
12470
12467
12465
12463
12462
12461
61
54
46
12458
12456
43
12455
29304
29303
29302
29300
12454
29299
29298
12453
29297