首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >颤动/Dart组列表(按日期)

颤动/Dart组列表(按日期)
EN

Stack Overflow用户
提问于 2020-05-29 01:11:36
回答 1查看 3.2K关注 0票数 1

我有下面的地图列表,

代码语言:javascript
运行
复制
[
   {
      "FullName":"Harry Potter",
      "DateOfBirth": "2020/02/16",
      "Department":"Branch Operation",
      "BirthDay":"Friday"
   },
   {
      "FullName":"John Wick",
      "DateOfBirth": "2020/02/16",
      "Department":"Finance",
      "BirthDay":"Friday"
   },
   {
      "FullName":"Solomon Kane",
      "DateOfBirth":2020/02/19,
      "Department":"Loan",
      "BirthDay":"Monday"
   }
]

我想要操作上面的数据,使数据按其DateOfBirth分组,因此结果将如下所示。

代码语言:javascript
运行
复制
[
   {
      "DateOfBirth": "2020/02/16",
      "BirthDay": "Friday",
      "Data":[
         {
            "FullName": "Harry Potter",
            "Department":"Branch Operation",
         },
         {
            "FullName":"John Wick",
            "Department":"Finance",
         }
      ]
   },
   {
      "DateOfBirth": "2020/02/19",
      "BirthDay": "Monday",
      "Data":[
         {
            "FullName":"Solomon Kane",
            "Department":"Loan"
         }
      ]
   },
]

在Javascript中,这可以通过使用reduce函数,然后使用对象键映射来实现。我还知道dart有一个很有用的包,叫做collection

因为我是个飞镖和扑扑新手,我不知道该怎么做。有人能帮我解决这个问题吗?

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-29 02:10:54

您可以使用fold并执行以下操作

代码语言:javascript
运行
复制
const data = [...];

void main() {
 final value = data.fold(Map<String, List<dynamic>>(), (Map<String, List<dynamic>> a, b) {
   a.putIfAbsent(b['DateOfBirth'], () => []).add(b);
   return a;
 }).values
   .where((l) => l.isNotEmpty)
   .map((l) => {
     'DateOfBirth': l.first['DateOfBirth'],
     'BirthDay': l.first['BirthDay'],
     'Data': l.map((e) => {
       'Department': e['Department'],
       'FullName': e['FullName'],
     }).toList()
 }).toList();
}

或者像这样,如果你想使用扩展运算符,我不知道它是否可读性很好。

代码语言:javascript
运行
复制
 final result = data.fold({}, (a, b) => {
     ...a,
     b['DateOfBirth']: [b, ...?a[b['DateOfBirth']]],
 }).values
   .where((l) => l.isNotEmpty)
   .map((l) => {
     'DateOfBirth': l.first['DateOfBirth'],
     'BirthDay': l.first['BirthDay'],
     'Data': l.map((e) => {
       'Department': e['Department'],
       'FullName': e['FullName'],
     }).toList()
 }).toList();
票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62070559

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档