자바스크립트 sort()를 이용한 숫자 정렬 정보
정규표현식 자바스크립트 sort()를 이용한 숫자 정렬본문
자바스크립트에서 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;
}
}
}
덧붙여서 대소문자 구분하지 않고 정렬합니다.
그래서 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에서 이동 됨]
추천
0
0
댓글 0개