Home > Software design >  Convert string into an object using reduce javascript
Convert string into an object using reduce javascript

Time:01-28

I am trying to convert a string like "sheep" into an object like this:

{
   "s":{
      "initial":1,
      "final":1
   },
   "h":{
      "initial":1,
      "final":1
   },
   "e":{
      "initial":2,
      "final":2
   },
   "p":{
      "initial":1,
      "final":1
   }
}

Currently I can use reduce method in javascript and achive this:

const names = 'sheep'.split('');
const count = (names) =>
  names.reduce((acc, name) => ({ ...acc, [name]: (acc[name] || 0)   1 }), {});
console.log(count(names)) //{ s: 1, h: 1, e: 2, p: 1 }

I have tried to read similar posts but I am pretty new to JS. Can anyone please help me? Thanks.

CodePudding user response:

Try like this

const names = "sheep".split("");
const count = (names) =>
  names.reduce(
    (acc, name) => ({
      ...acc,
      [name]: {
        initial: (acc?.[name]?.initial ?? 0)   1,
        final: (acc?.[name]?.final ?? 0)   1,
      },
    }),
    {}
  );
console.log(count(names)); 

CodePudding user response:

This works printing your desired output but I'm not sure why you want the initial and final counts to be the same

const letters = 'sheep'.split('');
const count = (letters) =>
  letters.reduce((obj, letter) => ({ ...obj, [letter]: {initial: (obj[letter]?.initial || 0)   1, final: (obj[letter]?.final || 0)   1} }), {});
console.log(count(letters)) 

Alternatively, you could expand a function there using braces and do some if's in order to have the code more readable instead of the ternaries

  •  Tags:  
  • Related