[英]How do I sum a key and group by value using Ramda?
我有這樣的數據:
const items = [
{category: 'food', amount: 5},
{category: 'food', amount: 5},
{category: 'transport', amount: 2},
{category: 'travel', amount: 11},
{category: 'travel', amount: 1},
]
如何按每個category
匯總amount
和分組,得出:
{
food : 10,
transport : 2,
travel : 12,
}
您可以使用reduceBy
:
R.reduceBy((acc, next) => acc + next.amount, 0, R.prop('category'))(items);
使用reduceBy
可能是個好主意。 如果您發現它有用,這里有一個替代方案。
從itemize
function 開始:
const itemize = ({category: c, amount: a}) => ({[c]: a});
itemize({category: 'food', amount: 5});
//=> {food: 5}
然后定義一個 function 可以添加或合並項目:
const additem = mergeWith(add);
additem({food: 5}, {food: 5});
//=> {food: 10}
additem({food: 5}, {transport: 2});
//=> {food: 5, transport: 2}
最后在reducer中使用這兩個函數:
reduce((a, b) => additem(a, itemize(b)), {}, items);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.