繁体   English   中英

如何在 dart/flutter 中按日期对列表进行排序/排序?

[英]How to sort/order a list by date in dart/flutter?

我有以下列表,我正在尝试按日期时间重新排序/排序。

import 'package:intl/intl.dart'; 
//don't forget to add under dependencies pubspec.yml "intl: ^0.15.8"


List products = [];

//adding into the new list from raw API list
for(final item in rawProducts){

   var parsedDate = DateTime.parse.(item['expiryDate']);
   tmpArray = {
     'id': item['id'],
     'name': item['name'],
     'price': item['price'],
     'expiry': parsedDate
   }
   products.add(tmpArray);
  }
}


List products = [

 {id: 1242, name: milk, price: $5, expiry: 2019-11-25 00:00:00:000},
 {id: 1242, name: egg, price: $2, expiry: 2019-11-22 00:00:00:000},
 {id: 1243, name: bread, price: $3, expiry: 2019-11-22 00:00:00:000},
 {id: 1244, name: butter, price: $7, expiry: 2019-11-24 00:00:00:000},
 {id: 1247, name: butter, price: $7, expiry: 2019-11-23 00:00:00:000},

]

我想以最远到期日期最先显示的方式重新排序列表:

 25-11-2019
 24-11-2019
 23-11-2019
 22-11-2019
 22-11-2019

我尝试过的(更新)-> 通过将a.expiry更改为a['expiry']解决了:

  products.sort((a,b) {
    var adate = a['expiry'] //before -> var adate = a.expiry;
     var bdate = b['expiry'] //var bdate = b.expiry;
     return -adate.compareTo(bdate);
  });

在排序功能上我收到此错误(通过上述修复解决):

Unhandled Exception: NoSuchMethodError: Class 
'_InternalLinkedHashMap<String, dynamic>'has no instance getter 'expiry'.

在上面的示例中, expiryString ,而不是 DateTime 对象。 您在这里有几个选择,具体取决于您想要实现的目标。

最简单的解决方案是使用 String 的内置compareTo方法,该方法允许对字符串进行排序。 这些时间戳已经是可排序的格式,所以这会起作用:

products.sort((a,b) {
    return a.compareTo(b);
 });

或者更简洁:

products.sort((a,b) => a.compareTo(b));

这是非常基本的。 就像评论中提到的 pskink 一样,以此为基础,您可以将字符串转换为实际的 DateTime 对象。

DateTime expiryAsDateTime = DateTime.parse(expiry);

DateTime也有一个内置的compareTo方法,因此上面的代码片段可以与 DateTimes 和 Strings 一起使用。

如果您想颠倒顺序,只需交换ab

我通过将changing a.expiry into a['expiry']并将b.expiry into b['expiry']修复它

products.sort((a,b) {
 var adate = a['expiry'] //before -> var adate = a.expiry;
 var bdate = b['expiry'] //before -> var bdate = b.expiry;
 return adate.compareTo(bdate); //to get the order other way just switch `adate & bdate`
});

转换为日期时间

import 'package:intl/intl.dart';

void main() {
  List products = [
    "2019-11-25 00:00:00.000",
    "2019-11-22 00:00:00.000",
    "2019-11-22 00:00:00.000",
    "2019-11-24 00:00:00.000",
    "2019-11-23 00:00:00.000"
  ];
  List<DateTime> newProducts = [];
  DateFormat format = DateFormat("yyyy-MM-dd");

  for (int i = 0; i < 5; i++) {
    newProducts.add(format.parse(products[i]));
  }
  newProducts.sort((a,b) => a.compareTo(b));

  for (int i = 0; i < 5; i++) {
    print(newProducts[i]);
  }
}

不转换为日期时间

import 'package:intl/intl.dart';

void main() {
  List products = [
    "2019-11-25 00:00:00.000",
    "2019-11-22 00:00:00.000",
    "2019-11-22 00:00:00.000",
    "2019-11-24 00:00:00.000",
    "2019-11-23 00:00:00.000"
  ];

  products.sort((a,b) => a.compareTo(b));

  for (int i = 0; i < 5; i++) {
    print(products[i]);
  }
}

如果您想按属性名称对对象进行排序而不必使用 DateTime 假设日期和时间是字符串,请执行以下操作:

products.sort((a, b)=> a['expiry'].compareTo(b['expiry']));

使用静态扩展方法排序:
select方法将expired值转换为DateTime类型的值。
orderBy方法按DateTime类型的值(e['expiry'] as DateTime )对序列进行排序。

import 'package:enumerable/enumerable.dart';
import 'package:intl/intl.dart';

void main() {
  final fmt = DateFormat('yyyy-M-d H:m:s:S');
  final query = rawProducts
      .select((p) => p..['expiry'] = fmt.parse(p['expiry'] as String))
      .orderBy((e) => e['expiry'] as DateTime);

  final products = query.toList();
  print(products);
}

List rawProducts = [
  {
    'id': 1242,
    'name': 'milk',
    'price': '\$5',
    'expiry': '2019-11-25 00:00:00:000'
  },
  {
    'id': 1242,
    'name': 'egg',
    'price': '\$2',
    'expiry': '2019-11-22 00:00:00:000'
  },
  {
    'id': 1243,
    'name': 'bread',
    'price': '\$3',
    'expiry': '2019-11-22 00:00:00:000'
  },
  {
    'id': 1244,
    'name': 'butter',
    'price': '\$7',
    'expiry': '2019-11-24 00:00:00:000'
  },
  {
    'id': 1247,
    'name': 'butter',
    'price': '\$7',
    'expiry': '2019-11-23 00:00:00:000'
  },
];

如果你有类似的东西:

{
"id": 100,
"timestamp": "2021-02-02T15:15:11Z",
"name": "Entry1"
}

然后这样做:

List<Values> _myList = [];
_myList.sort((a,b)=> a["timestamp"].compareTo(b["timestamp"])); 

或者像我的代码:

task.sort((a,b) => a.createdAt.compareTo(b.createdAt));

来源

如果我们变得更具体,那么试试这个。

它对我来说非常有用


transactionList.sort((a, b) {
  int aDate = DateTime.parse(a.dateTime ?? '').microsecondsSinceEpoch;
  int bDate = DateTime.parse(b.dateTime ?? '').microsecondsSinceEpoch;
  return aDate.compareTo(bDate);
});

对我来说,我需要在 compareTo 之前先使用 DateTime.parse

https://www.fluttercampus.com/guide/169/how-to-sort-list-by-date-in-dart-flutter/

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM