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

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

· 18년 전 · 4157
자바스크립트에서 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에서 이동 됨]

댓글 작성

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

로그인하기

게시글 목록

번호 제목
11797
11796
29161
11795
11794
11793
11789
11784
29160
11781
11778
24966
24964
24963
24961
24960
24950
24948
24947
24946
24945
24944
24943
24942
24941
24940
24939
29158
11777
11774
11772
11771
11770
11769
11765
11764
11763
11758
29148
11752
11747
11746
29147
11744
11735
29145
11733
11731
11730
24937
11728
11727
11725
11717
29138
11716
11715
11714
11711
11710
11708
11700
11697
24936
24935
24934
24933
24932
24931
24930
24929
24928
24927
24926
24925
24922
24921
24920
24919
24918
24917
24916
24915
24914
24913
11696
11694
24912
24911
24910
24909
24908
24907
24906
11692
24905
24904
24903
24902
24901