Reduce array of object to totals by property object The 2019 Stack Overflow Developer Survey Results Are InDetecting an undefined object propertyWhat is the most efficient way to deep clone an object in JavaScript?How can I merge properties of two JavaScript objects dynamically?How do I remove a property from a JavaScript object?How do I check if an array includes an object in JavaScript?Sort array of objects by string property valueHow to check if an object is an array?How do I remove a particular element from an array in JavaScript?Iterate through object propertiesHow to use foreach with array in JavaScript?

Command for nulifying spaces

Pokemon Turn Based battle (Python)

What do hard-Brexiteers want with respect to the Irish border?

How much of the clove should I use when using big garlic heads?

How to deal with speedster characters?

What information about me do stores get via my credit card?

Did any laptop computers have a built-in 5 1/4 inch floppy drive?

Omit the same coordinate parameters in drawing line in tikz

What do the Banks children have against barley water?

One word riddle: Vowel in the middle

Is it ethical to upload a automatically generated paper to a non peer-reviewed site as part of a larger research?

Button changing its text & action. Good or terrible?

slides for 30min~1hr skype tenure track application interview

Did Scotland spend $250,000 for the slogan "Welcome to Scotland"?

How do I free up internal storage if I don't have any apps downloaded?

How to notate time signature switching consistently every measure

Why isn't the circumferential light around the M87 black hole's event horizon symmetric?

What does Linus Torvalds mean when he says that Git "never ever" tracks a file?

Loose spokes after only a few rides

How can I add encounters in the Lost Mine of Phandelver campaign without giving PCs too much XP?

Why was M87 targetted for the Event Horizon Telescope instead of Sagittarius A*?

Why didn't the Event Horizon Telescope team mention Sagittarius A*?

Ubuntu Server install with full GUI

Should I use my personal e-mail address, or my workplace one, when registering to external websites for work purposes?



Reduce array of object to totals by property object



The 2019 Stack Overflow Developer Survey Results Are InDetecting an undefined object propertyWhat is the most efficient way to deep clone an object in JavaScript?How can I merge properties of two JavaScript objects dynamically?How do I remove a property from a JavaScript object?How do I check if an array includes an object in JavaScript?Sort array of objects by string property valueHow to check if an object is an array?How do I remove a particular element from an array in JavaScript?Iterate through object propertiesHow to use foreach with array in JavaScript?



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








6















I'm looking for a smart ES6 way to reduce array of objects into totals-by-property-object.



for a sample data:



const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];


following code:



const res = src.reduce((totals,item) => Object.keys(item).forEach(weekday => totals[weekday] += item[weekday]),)


throws an error:




Uncaught TypeError: Cannot read property 'mon' of undefined




even if reduce is initialized with mon:0, tue:0 ... instead of .



Is there a non-for-loop solution?



p.s. expected output is an object where each property is a sum of array objects by that property, e.g. mon:6, tue:3, wed:5, thu:5, fri:8, sat:0, sun:10 in my case










share|improve this question






























    6















    I'm looking for a smart ES6 way to reduce array of objects into totals-by-property-object.



    for a sample data:



    const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];


    following code:



    const res = src.reduce((totals,item) => Object.keys(item).forEach(weekday => totals[weekday] += item[weekday]),)


    throws an error:




    Uncaught TypeError: Cannot read property 'mon' of undefined




    even if reduce is initialized with mon:0, tue:0 ... instead of .



    Is there a non-for-loop solution?



    p.s. expected output is an object where each property is a sum of array objects by that property, e.g. mon:6, tue:3, wed:5, thu:5, fri:8, sat:0, sun:10 in my case










    share|improve this question


























      6












      6








      6


      0






      I'm looking for a smart ES6 way to reduce array of objects into totals-by-property-object.



      for a sample data:



      const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];


      following code:



      const res = src.reduce((totals,item) => Object.keys(item).forEach(weekday => totals[weekday] += item[weekday]),)


      throws an error:




      Uncaught TypeError: Cannot read property 'mon' of undefined




      even if reduce is initialized with mon:0, tue:0 ... instead of .



      Is there a non-for-loop solution?



      p.s. expected output is an object where each property is a sum of array objects by that property, e.g. mon:6, tue:3, wed:5, thu:5, fri:8, sat:0, sun:10 in my case










      share|improve this question
















      I'm looking for a smart ES6 way to reduce array of objects into totals-by-property-object.



      for a sample data:



      const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];


      following code:



      const res = src.reduce((totals,item) => Object.keys(item).forEach(weekday => totals[weekday] += item[weekday]),)


      throws an error:




      Uncaught TypeError: Cannot read property 'mon' of undefined




      even if reduce is initialized with mon:0, tue:0 ... instead of .



      Is there a non-for-loop solution?



      p.s. expected output is an object where each property is a sum of array objects by that property, e.g. mon:6, tue:3, wed:5, thu:5, fri:8, sat:0, sun:10 in my case







      javascript ecmascript-6






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Mar 29 at 13:18







      user11154868

















      asked Mar 29 at 13:13









      user11154868user11154868

      334




      334






















          2 Answers
          2






          active

          oldest

          votes


















          5














          You need to return totals after you modify it:






          const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];

          const res = src.reduce((totals, item) =>
          Object.keys(item).forEach(weekday => totals[weekday] = (totals[weekday] , );

          console.log(res);








          share|improve this answer




















          • 3





            I can't believe it was that close. Thanks a lot.

            – user11154868
            Mar 29 at 13:24


















          4














          You need to return totals as accumulator for reduce.



          If you have allways all days in the objects and you don't mind to mutate the first object, you could work without a start object.






          const
          src = [ mon: 1, tue: 0, wed: 3, thu: 5, fri: 7, sat: 0, sun: 4 , mon: 5, tue: 3, wed: 2, thu: 0, fri: 1, sat: 0, sun: 6 ],
          res = src.reduce((totals, item) =>
          (Object.keys(item).forEach(d => totals[d] += item[d]), totals));

          console.log(res);








          share|improve this answer























            Your Answer






            StackExchange.ifUsing("editor", function ()
            StackExchange.using("externalEditor", function ()
            StackExchange.using("snippets", function ()
            StackExchange.snippets.init();
            );
            );
            , "code-snippets");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "1"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader:
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            ,
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













            draft saved

            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55418223%2freduce-array-of-object-to-totals-by-property-object%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown

























            2 Answers
            2






            active

            oldest

            votes








            2 Answers
            2






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            5














            You need to return totals after you modify it:






            const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];

            const res = src.reduce((totals, item) =>
            Object.keys(item).forEach(weekday => totals[weekday] = (totals[weekday] , );

            console.log(res);








            share|improve this answer




















            • 3





              I can't believe it was that close. Thanks a lot.

              – user11154868
              Mar 29 at 13:24















            5














            You need to return totals after you modify it:






            const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];

            const res = src.reduce((totals, item) =>
            Object.keys(item).forEach(weekday => totals[weekday] = (totals[weekday] , );

            console.log(res);








            share|improve this answer




















            • 3





              I can't believe it was that close. Thanks a lot.

              – user11154868
              Mar 29 at 13:24













            5












            5








            5







            You need to return totals after you modify it:






            const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];

            const res = src.reduce((totals, item) =>
            Object.keys(item).forEach(weekday => totals[weekday] = (totals[weekday] , );

            console.log(res);








            share|improve this answer















            You need to return totals after you modify it:






            const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];

            const res = src.reduce((totals, item) =>
            Object.keys(item).forEach(weekday => totals[weekday] = (totals[weekday] , );

            console.log(res);








            const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];

            const res = src.reduce((totals, item) =>
            Object.keys(item).forEach(weekday => totals[weekday] = (totals[weekday] , );

            console.log(res);





            const src = [mon:1,tue:0,wed:3,thu:5,fri:7,sat:0,sun:4, mon:5,tue:3,wed:2,thu:0,fri:1,sat:0,sun:6];

            const res = src.reduce((totals, item) =>
            Object.keys(item).forEach(weekday => totals[weekday] = (totals[weekday] , );

            console.log(res);






            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited Apr 1 at 4:52

























            answered Mar 29 at 13:17









            Ori DroriOri Drori

            82.3k148998




            82.3k148998







            • 3





              I can't believe it was that close. Thanks a lot.

              – user11154868
              Mar 29 at 13:24












            • 3





              I can't believe it was that close. Thanks a lot.

              – user11154868
              Mar 29 at 13:24







            3




            3





            I can't believe it was that close. Thanks a lot.

            – user11154868
            Mar 29 at 13:24





            I can't believe it was that close. Thanks a lot.

            – user11154868
            Mar 29 at 13:24













            4














            You need to return totals as accumulator for reduce.



            If you have allways all days in the objects and you don't mind to mutate the first object, you could work without a start object.






            const
            src = [ mon: 1, tue: 0, wed: 3, thu: 5, fri: 7, sat: 0, sun: 4 , mon: 5, tue: 3, wed: 2, thu: 0, fri: 1, sat: 0, sun: 6 ],
            res = src.reduce((totals, item) =>
            (Object.keys(item).forEach(d => totals[d] += item[d]), totals));

            console.log(res);








            share|improve this answer



























              4














              You need to return totals as accumulator for reduce.



              If you have allways all days in the objects and you don't mind to mutate the first object, you could work without a start object.






              const
              src = [ mon: 1, tue: 0, wed: 3, thu: 5, fri: 7, sat: 0, sun: 4 , mon: 5, tue: 3, wed: 2, thu: 0, fri: 1, sat: 0, sun: 6 ],
              res = src.reduce((totals, item) =>
              (Object.keys(item).forEach(d => totals[d] += item[d]), totals));

              console.log(res);








              share|improve this answer

























                4












                4








                4







                You need to return totals as accumulator for reduce.



                If you have allways all days in the objects and you don't mind to mutate the first object, you could work without a start object.






                const
                src = [ mon: 1, tue: 0, wed: 3, thu: 5, fri: 7, sat: 0, sun: 4 , mon: 5, tue: 3, wed: 2, thu: 0, fri: 1, sat: 0, sun: 6 ],
                res = src.reduce((totals, item) =>
                (Object.keys(item).forEach(d => totals[d] += item[d]), totals));

                console.log(res);








                share|improve this answer













                You need to return totals as accumulator for reduce.



                If you have allways all days in the objects and you don't mind to mutate the first object, you could work without a start object.






                const
                src = [ mon: 1, tue: 0, wed: 3, thu: 5, fri: 7, sat: 0, sun: 4 , mon: 5, tue: 3, wed: 2, thu: 0, fri: 1, sat: 0, sun: 6 ],
                res = src.reduce((totals, item) =>
                (Object.keys(item).forEach(d => totals[d] += item[d]), totals));

                console.log(res);








                const
                src = [ mon: 1, tue: 0, wed: 3, thu: 5, fri: 7, sat: 0, sun: 4 , mon: 5, tue: 3, wed: 2, thu: 0, fri: 1, sat: 0, sun: 6 ],
                res = src.reduce((totals, item) =>
                (Object.keys(item).forEach(d => totals[d] += item[d]), totals));

                console.log(res);





                const
                src = [ mon: 1, tue: 0, wed: 3, thu: 5, fri: 7, sat: 0, sun: 4 , mon: 5, tue: 3, wed: 2, thu: 0, fri: 1, sat: 0, sun: 6 ],
                res = src.reduce((totals, item) =>
                (Object.keys(item).forEach(d => totals[d] += item[d]), totals));

                console.log(res);






                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Mar 29 at 13:17









                Nina ScholzNina Scholz

                197k15110179




                197k15110179



























                    draft saved

                    draft discarded
















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid


                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.

                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55418223%2freduce-array-of-object-to-totals-by-property-object%23new-answer', 'question_page');

                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Adding axes to figuresAdding axes labels to LaTeX figuresLaTeX equivalent of ConTeXt buffersRotate a node but not its content: the case of the ellipse decorationHow to define the default vertical distance between nodes?TikZ scaling graphic and adjust node position and keep font sizeNumerical conditional within tikz keys?adding axes to shapesAlign axes across subfiguresAdding figures with a certain orderLine up nested tikz enviroments or how to get rid of themAdding axes labels to LaTeX figures

                    Luettelo Yhdysvaltain laivaston lentotukialuksista Lähteet | Navigointivalikko

                    Gary (muusikko) Sisällysluettelo Historia | Rockin' High | Lähteet | Aiheesta muualla | NavigointivalikkoInfobox OKTuomas "Gary" Keskinen Ancaran kitaristiksiProjekti Rockin' High