날짜 속성으로 배열을 정렬하는 방법


698

몇 개의 객체 배열이 있다고 가정 해보십시오.

var array = [{id: 1, date: Mar 12 2012 10:00:00 AM}, {id: 2, date: Mar 8 2012 08:00:00 AM}];

이 배열을 날짜 요소를 기준으로 가장 가까운 날짜부터 현재 날짜 및 시간이 지날 때까지 어떻게 정렬 할 수 있습니까? 배열에는 많은 객체가있을 수 있지만 단순성을 위해 2를 사용했습니다.

정렬 기능과 사용자 지정 비교기를 사용합니까?

최신 정보:

내 경우에는 가장 최근 날짜부터 가장 오래된 날짜까지 정렬하고 싶었습니다. 결국 간단한 함수의 논리를 반대로 바꿔야했습니다.

array.sort(function(a, b) {
    a = new Date(a.dateModified);
    b = new Date(b.dateModified);
    return a>b ? -1 : a<b ? 1 : 0;
});

가장 최근 날짜를 정렬합니다.


Date 생성자를 사용하는 경우이 첫 번째 stackoverflow.com/questions/5619202/…를
ohkts11

가장 빠른 방법은 브라우저와 노드 모두에서 기본적으로 작동하는 모든 유형의 입력, 계산 필드 및 사용자 정의 정렬 순서를 지원 하는 동형 정렬 배열 모듈 을 사용하는 것 입니다.
Lloyd

답변:


1406

가장 간단한 답변

array.sort(function(a,b){
  // Turn your strings into dates, and then subtract them
  // to get a value that is either negative, positive, or zero.
  return new Date(b.date) - new Date(a.date);
});

더 일반적인 답변

array.sort(function(o1,o2){
  if (sort_o1_before_o2)    return -1;
  else if(sort_o1_after_o2) return  1;
  else                      return  0;
});

또는 더 간결하게 :

array.sort(function(o1,o2){
  return sort_o1_before_o2 ? -1 : sort_o1_after_o2 ? 1 : 0;
});

일반적인 강력한 답변

모든 배열 sortBy에서 Schwartzian 변환 을 사용하여 열거 불가능한 사용자 정의 함수를 정의하십시오 .

(function(){
  if (typeof Object.defineProperty === 'function'){
    try{Object.defineProperty(Array.prototype,'sortBy',{value:sb}); }catch(e){}
  }
  if (!Array.prototype.sortBy) Array.prototype.sortBy = sb;

  function sb(f){
    for (var i=this.length;i;){
      var o = this[--i];
      this[i] = [].concat(f.call(o,o,i),o);
    }
    this.sort(function(a,b){
      for (var i=0,len=a.length;i<len;++i){
        if (a[i]!=b[i]) return a[i]<b[i]?-1:1;
      }
      return 0;
    });
    for (var i=this.length;i;){
      this[--i]=this[i][this[i].length-1];
    }
    return this;
  }
})();

다음과 같이 사용하십시오.

array.sortBy(function(o){ return o.date });

날짜가 직접 비교 가능하지 않은 경우, 비교 가능한 날짜를 작성하십시오 (예 :

array.sortBy(function(o){ return new Date( o.date ) });

값 배열을 반환하는 경우이를 사용하여 여러 기준으로 정렬 할 수도 있습니다.

// Sort by date, then score (reversed), then name
array.sortBy(function(o){ return [ o.date, -o.score, o.name ] };

자세한 내용은 http://phrogz.net/JS/Array.prototype.sortBy.js 를 참조하십시오.


2
return b-a;단순 답변에 없는가?
corbacho

19
sort 메서드 안에 새로운 Date 객체를 만드는 것은 권장하지 않습니다. 그런 이유로 생산 성능 문제를 겪었습니다. 정렬 방법 내에 메모리 (및 GC)를 할당하지 마십시오.
MikeMurko

4
첫 번째 예 구문은 angular7에서 오류를 발생시킵니다. 산술 연산의 왼쪽은 'any', 'number', 'bigint'또는 열거 형
이어야

1
@MikeMurko 당신은 그것을 고치기 위해 무엇을 했습니까?
Sireini

@SURENDRANATHSONAWANE는 Date를 Unix Timestamp로 변환합니다 : return new Date (b.date) .getTime ()-new Date (a.date) .getTime ();
Robert Ostrowicki

147

@Phrogz 답변은 모두 훌륭하지만 다음은 훌륭하고 간결한 답변입니다.

array.sort(function(a,b){return a.getTime() - b.getTime()});

화살표 기능 사용

array.sort((a,b)=>a.getTime()-b.getTime());

여기에서 찾았습니다 : 자바 스크립트에서 날짜 정렬


15
수학을 직접하는 a - b것도 효과가 있습니다. 그래서, array.sort((a, b) => a - b)(es6)
yckart

Typescript를 사용할 때 좋은 해결책입니다.
maartenpaauw

72

JSON을 수정 한 후에는 다음과 같이 작동합니다.

var array = [{id: 1, date:'Mar 12 2012 10:00:00 AM'}, {id: 2, date:'Mar 8 2012 08:00:00 AM'}];


array.sort(function(a, b) {
    var c = new Date(a.date);
    var d = new Date(b.date);
    return c-d;
});

45

데이터를 수정해야합니다.

var array = [{id: 1, date: "Mar 12 2012 10:00:00 AM"},{id: 2, date: "Mar 28 2012 08:00:00 AM"}];

데이터를 수정 한 후 다음 코드를 사용할 수 있습니다.

function sortFunction(a,b){  
    var dateA = new Date(a.date).getTime();
    var dateB = new Date(b.date).getTime();
    return dateA > dateB ? 1 : -1;  
}; 

var array = [{id: 1, date: "Mar 12 2012 10:00:00 AM"},{id: 2, date: "Mar 28 2012 08:00:00 AM"}];
array.sort(sortFunction);​


Typescript를 사용하는 사람은이 기능을 사용하여 날짜별로 정렬 할 수 있었지만 날짜 빼기를 사용하는 다른 사람은 실패했습니다.
Danchat

24

GitHub를 추천합니다 : Array sortBy - Schwartzian 변환sortBy 을 사용 하는 최상의 방법 구현

그러나 지금은 Gist : sortBy-old.js 접근 방식을 시도 할 것 입니다.
속성을 기준으로 객체를 정렬 할 수있는 배열을 정렬하는 메서드를 만들어 보겠습니다.

정렬 기능 만들기

var sortBy = (function () {
  var toString = Object.prototype.toString,
      // default parser function
      parse = function (x) { return x; },
      // gets the item to be sorted
      getItem = function (x) {
        var isObject = x != null && typeof x === "object";
        var isProp = isObject && this.prop in x;
        return this.parser(isProp ? x[this.prop] : x);
      };

  /**
   * Sorts an array of elements.
   *
   * @param {Array} array: the collection to sort
   * @param {Object} cfg: the configuration options
   * @property {String}   cfg.prop: property name (if it is an Array of objects)
   * @property {Boolean}  cfg.desc: determines whether the sort is descending
   * @property {Function} cfg.parser: function to parse the items to expected type
   * @return {Array}
   */
  return function sortby (array, cfg) {
    if (!(array instanceof Array && array.length)) return [];
    if (toString.call(cfg) !== "[object Object]") cfg = {};
    if (typeof cfg.parser !== "function") cfg.parser = parse;
    cfg.desc = !!cfg.desc ? -1 : 1;
    return array.sort(function (a, b) {
      a = getItem.call(cfg, a);
      b = getItem.call(cfg, b);
      return cfg.desc * (a < b ? -1 : +(a > b));
    });
  };

}());

정렬되지 않은 데이터 설정

var data = [
  {date: "2011-11-14T17:25:45Z", quantity: 2, total: 200, tip: 0,   type: "cash"},
  {date: "2011-11-14T16:28:54Z", quantity: 1, total: 300, tip: 200, type: "visa"},
  {date: "2011-11-14T16:30:43Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T17:22:59Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:53:41Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:48:46Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-31T17:29:52Z", quantity: 1, total: 200, tip: 100, type: "visa"},
  {date: "2011-11-01T16:17:54Z", quantity: 2, total: 190, tip: 100, type: "tab"},
  {date: "2011-11-14T16:58:03Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:20:19Z", quantity: 2, total: 190, tip: 100, type: "tab"},
  {date: "2011-11-14T17:07:21Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:54:06Z", quantity: 1, total: 100, tip: 0,   type: "cash"}
];

그것을 사용하여

마지막으로 "date"속성 별로 배열을 정렬합니다.string

//sort the object by a property (ascending)
//sorting takes into account uppercase and lowercase
sortBy(data, { prop: "date" });

대소 문자를 무시하려면 "parser"콜백을 설정하십시오 .

//sort the object by a property (descending)
//sorting ignores uppercase and lowercase
sortBy(data, {
    prop: "date",
    desc: true,
    parser: function (item) {
        //ignore case sensitive
        return item.toUpperCase();
    }
});

"날짜"필드를 Date유형 으로 취급하려면 다음을 수행하십시오.

//sort the object by a property (ascending)
//sorting parses each item to Date type
sortBy(data, {
    prop: "date",
    parser: function (item) {
        return new Date(item);
    }
});

jsbin.com/lesebi 예제를 사용하여 재생할 수 있습니다.


1
IE11의 줄에 문제가있었습니다 : if (toString.call (cfg)! == "[object Object]") cfg = {}; if (Object.prototype.toString.call (cfg)! == "[object Object]")로 바꾸면 cfg = {}; IE11도 모두 잘 사용할 것입니다.
skribbz14

1
탁월한 솔루션
Moses Machua

14

날짜가이 형식 (dd / mm / yyyy) 일 때 수행해야합니다.

  sortByDate(arr) {
    arr.sort(function(a,b){
      return Number(new Date(a.readableDate)) - Number(new Date(b.readableDate));
    });

    return arr;
  }

그런 다음 전화 sortByDate(myArr);


12

밑줄 js에서 sortBy를 사용할 수 있습니다.

http://underscorejs.org/#sortBy

견본:

var log = [{date: '2016-01-16T05:23:38+00:00', other: 'sample'}, 
           {date: '2016-01-13T05:23:38+00:00',other: 'sample'}, 
           {date: '2016-01-15T11:23:38+00:00', other: 'sample'}];

console.log(_.sortBy(log, 'date'));

완벽하고 짧은 방법!
Bhavik Kalariya

8

일부 용도로는이 정렬 방법을 뒤집는 방법을 찾지 못할 수도 있으므로 여기에 추가하겠습니다.

'coming up'을 기준으로 정렬하려면 다음과 같이 간단히 a & b를 바꿀 수 있습니다.

your_array.sort ( (a, b) => {
      return new Date(a.DateTime) - new Date(b.DateTime);
});

공지 사항 a왼쪽에 지금하고 b, 오른쪽에 있습니다 : D!


7

나는 개인적으로 다음과 같은 접근법을 사용하여 날짜를 정렬합니다.

let array = ["July 11, 1960", "February 1, 1974", "July 11, 1615", "October 18, 1851", "November 12, 1995"];

array.sort(function(date1, date2) {
   date1 = new Date(date1);
   date2 = new Date(date2);
   if (date1 > date2) return 1;
   if (date1 < date2) return -1;
})

6

아래 줄을 사용하여 정렬을 수행 할 수있었습니다.

array.sort(function(a, b)
{
   if (a.DueDate > b.DueDate) return 1;
   if (a.DueDate < b.DueDate) return -1;
})

5
Adding absolute will give better results

var datesArray =[
      {"some":"data1","date": "2018-06-30T13:40:31.493Z"},
      {"some":"data2","date": "2018-07-04T13:40:31.493Z"},
      {"some":"data3","date": "2018-06-27T13:40:54.394Z"}
   ]

var sortedJsObjects = datesArray.sort(function(a,b){ 
    return Math.abs(new Date(a.date) - new Date(b.date)) 
});

2

날짜별로 정렬하려는 사람 (영국 형식)을 위해 다음을 사용했습니다.

//Sort by day, then month, then year
for(i=0;i<=2; i++){
    dataCourses.sort(function(a, b){

        a = a.lastAccessed.split("/");
        b = b.lastAccessed.split("/");

        return a[i]>b[i] ? -1 : a[i]<b[i] ? 1 : 0;
    }); 
}

2

난 그냥 찍은 찌언 변환 위의 묘사와 함수로했다. 그것은을 얻어 array, 정렬 function입력으로 부울 :

function schwartzianSort(array,f,asc){
    for (var i=array.length;i;){
      var o = array[--i];
      array[i] = [].concat(f.call(o,o,i),o);
    }
    array.sort(function(a,b){
      for (var i=0,len=a.length;i<len;++i){
        if (a[i]!=b[i]) return a[i]<b[i]?asc?-1:1:1;
      }
      return 0;
    });
    for (var i=array.length;i;){
      array[--i]=array[i][array[i].length-1];
    }
    return array;
  }

function schwartzianSort(array, f, asc) {
  for (var i = array.length; i;) {
    var o = array[--i];
    array[i] = [].concat(f.call(o, o, i), o);
  }
  array.sort(function(a, b) {
    for (var i = 0, len = a.length; i < len; ++i) {
      if (a[i] != b[i]) return a[i] < b[i] ? asc ? -1 : 1 : 1;
    }
    return 0;
  });
  for (var i = array.length; i;) {
    array[--i] = array[i][array[i].length - 1];
  }
  return array;
}

arr = []
arr.push({
  date: new Date(1494434112806)
})
arr.push({
  date: new Date(1494434118181)
})
arr.push({
  date: new Date(1494434127341)
})

console.log(JSON.stringify(arr));

arr = schwartzianSort(arr, function(o) {
  return o.date
}, false)
console.log("DESC", JSON.stringify(arr));

arr = schwartzianSort(arr, function(o) {
  return o.date
}, true)
console.log("ASC", JSON.stringify(arr));


2

Ganesh Sanap에게 감사합니다. 날짜 필드를 기준으로 항목을 기존 항목에서 새로운 항목으로 정렬합니다. 사용해

 myArray = [{transport: "Air",
             load: "Vatican Vaticano",
             created: "01/31/2020"},
            {transport: "Air",
             load: "Paris",
             created: "01/30/2020"}] 

        myAarray.sort(function(a, b) {
            var c = new Date(a.created);
            var d = new Date(b.created);
            return c-d;
        });

1
이유는 무엇입니까?
Янов Алексей

2

YYYY[-MM[-DD]]처럼 특정 날짜보다 덜 구체적인 날짜를 주문 하려는 경우와 같이 날짜 형식이 지정된 배열 이있는 경우이 편리한 기능을 생각해 냈습니다.

function sortByDateSpecificity(a, b) {
  const aLength = a.date.length
  const bLength = b.date.length
  const aDate = a.date + (aLength < 10 ? '-12-31'.slice(-10 + aLength) : '')
  const bDate = b.date + (bLength < 10 ? '-12-31'.slice(-10 + bLength) : '')
  return new Date(aDate) - new Date(bDate)
}

0
["12 Jan 2018" , "1 Dec 2018", "04 May 2018"].sort(function(a,b) {
    return new Date(a).getTime() - new Date(b).getTime()
})

답변을 간단히 설명하고 코드 형식을 확인하십시오.
dthulke

오래된 날짜에 실패합니다.
Oliver Dixon
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.