首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ramda.js如何做groupby,计数,排序

ramda.js如何做groupby,计数,排序
EN

Stack Overflow用户
提问于 2020-05-02 01:02:17
回答 3查看 361关注 0票数 0

我有一个数据集合,比如:

代码语言:javascript
复制
[{"id":1,"score":4},{"id":2,"score":3},{"id":1,"score":4},{"id":2,"score":3},{"id":3,"score":4},{"id":1,"score":3}]

我希望输出如下:

代码语言:javascript
复制
[{"id":1,"count":3},{"id":2,"count":2},{"id":3,"count":1}]

有没有什么解决方案可以使用Ramda.js来做到这一点?

我试着使用countBy(prop("id")),但我想不出按计数排序的方法。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-05-02 01:22:28

使用R.pipe创建一个函数,该函数使用R.countBy获取{ [id]: count }的对象,然后将数据转换为对,并使用R.map和R.applySpec生成对象数组。然后使用R.sortBy对其进行排序。

代码语言:javascript
复制
const { pipe, countBy, prop, toPairs, map, applySpec, head, last, sortBy, descend } = R

const fn = pipe(
  countBy(prop('id')),
  toPairs,
  map(applySpec({
    id: pipe(head, Number), // or just id: head if the id doesn't have to be a number
    count: last,
  })),
  sortBy(descend(prop('count'))), // or ascend
)

const arr = [{"id":1,"score":4},{"id":2,"score":3},{"id":1,"score":4},{"id":2,"score":3},{"id":3,"score":4},{"id":1,"score":3}]

const result = fn(arr)

console.log(result)
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.27.0/ramda.js"></script>

票数 3
EN

Stack Overflow用户

发布于 2020-05-02 01:50:45

显然,如果您使用的是Ramda,那么countBy将是解决方案的一部分。然后,我会选择通过管道将其传递给toPairszipObj,以获得最终结果:

代码语言:javascript
复制
const collect = pipe (
  countBy (prop ('id')),
  toPairs,
  map (zipObj (['id', 'count']))
) 

const data = [{id: 1, score: 4}, {id: 2, score: 3}, {id: 1, score: 4}, {id: 2, score: 3}, {id: 3, score: 4},{id: 1, score: 3}]

console .log (collect (data))
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.27.0/ramda.js"></script>
<script> const {pipe, countBy, prop, toPairs, map, zipObj} = R             </script>

zipObj接受一个属性名称数组和一个值数组,并将它们压缩成一个对象。

票数 1
EN

Stack Overflow用户

发布于 2020-05-02 01:09:37

使用vanillaJS,您可以简单地使用reduce和Map

代码语言:javascript
复制
const data = [{"id":1,"score":4},{"id":2,"score":3},{"id":1,"score":4},{"id":2,"score":3},{"id":3,"score":4},{"id":1,"score":3}]

const final = [...data.reduce((op,{id,score})=>{
   if(op.has(id)){
    op.set(id, op.get(id)+1)
   } else {
    op.set(id,1)
   }
   return op;
}, new Map()).entries()].map(([id,count])=>({id,count}))

console.log(final)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61547078

复制
相关文章

相似问题

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