Averaging over columns while ignoring zero entriesOperations on a List of Vectors (Norm)Compute percentages...

What do you call someone who likes to pick fights?

How to write a chaotic neutral protagonist and prevent my readers from thinking they are evil?

Is this Paypal Github SDK reference really a dangerous site?

Getting the || sign while using Kurier

Having the player face themselves after the mid-game

Can I negotiate a patent idea for a raise, under French law?

Is it possible that a question has only two answers?

Is it a Cyclops number? "Nobody" knows!

When a wind turbine does not produce enough electricity how does the power company compensate for the loss?

How do we create new idioms and use them in a novel?

Giving a career talk in my old university, how prominently should I tell students my salary?

What is the generally accepted pronunciation of “topoi”?

I can't die. Who am I?

I need help with tikz tree node and label, offsets and inclination

Is it safe to abruptly remove Arduino power?

PTIJ: Why does only a Shor Tam ask at the Seder, and not a Shor Mu'ad?

What is better: yes / no radio, or simple checkbox?

Which situations would cause a company to ground or recall a aircraft series?

What is this diamond of every day?

Does "Until when" sound natural for native speakers?

For which categories of spectra is there an explicit description of the fibrant objects via lifting properties?

Are there historical instances of the capital of a colonising country being temporarily or permanently shifted to one of its colonies?

How can I find out information about a service?

Confusion about Complex Continued Fraction



Averaging over columns while ignoring zero entries


Operations on a List of Vectors (Norm)Compute percentages in a listElegant way to map a function over the columns of an arrayHow to count number of observations/rows within each groupHow can Tally group elements that differ only by a sign together?Creating Average Grid data from Co-ordinate and value dataList manipulation, averaging over lists and fidelityHow to select elements from a list of pairs based on 2nd element of the pairSubtract value from listHow to list ArrayFilter?













5












$begingroup$


I have:



list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, 
{1, 0, 2, 2, 2, 4, 0}}


I want to calculate the average but without considering the 0s.



The result should be:



Do[
array = list[[All, i]];
total = Total[array];
cnt = Count[array, 0];
result[[i]] = total/(Length@array - cnt);,
{i, 1, Length@result}
];

result // N

{2., 3., 3., 4., 4., 3., 9.}


How can I replace the Do loop?










share|improve this question











$endgroup$








  • 1




    $begingroup$
    Mean /@ DeleteCases[Transpose@list, 0, All]
    $endgroup$
    – MarcoB
    2 days ago










  • $begingroup$
    Thank you for the solution.
    $endgroup$
    – lio
    2 days ago












  • $begingroup$
    You’re welcome. I’ve added an answer since this solution works for you
    $endgroup$
    – MarcoB
    2 days ago








  • 4




    $begingroup$
    I'm not at a computer right now, so please try Total[list]/Total[Unitize[list]].
    $endgroup$
    – J. M. is computer-less
    2 days ago










  • $begingroup$
    @J.M. Well, that is clever! Cool trick :-)
    $endgroup$
    – MarcoB
    2 days ago
















5












$begingroup$


I have:



list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, 
{1, 0, 2, 2, 2, 4, 0}}


I want to calculate the average but without considering the 0s.



The result should be:



Do[
array = list[[All, i]];
total = Total[array];
cnt = Count[array, 0];
result[[i]] = total/(Length@array - cnt);,
{i, 1, Length@result}
];

result // N

{2., 3., 3., 4., 4., 3., 9.}


How can I replace the Do loop?










share|improve this question











$endgroup$








  • 1




    $begingroup$
    Mean /@ DeleteCases[Transpose@list, 0, All]
    $endgroup$
    – MarcoB
    2 days ago










  • $begingroup$
    Thank you for the solution.
    $endgroup$
    – lio
    2 days ago












  • $begingroup$
    You’re welcome. I’ve added an answer since this solution works for you
    $endgroup$
    – MarcoB
    2 days ago








  • 4




    $begingroup$
    I'm not at a computer right now, so please try Total[list]/Total[Unitize[list]].
    $endgroup$
    – J. M. is computer-less
    2 days ago










  • $begingroup$
    @J.M. Well, that is clever! Cool trick :-)
    $endgroup$
    – MarcoB
    2 days ago














5












5








5





$begingroup$


I have:



list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, 
{1, 0, 2, 2, 2, 4, 0}}


I want to calculate the average but without considering the 0s.



The result should be:



Do[
array = list[[All, i]];
total = Total[array];
cnt = Count[array, 0];
result[[i]] = total/(Length@array - cnt);,
{i, 1, Length@result}
];

result // N

{2., 3., 3., 4., 4., 3., 9.}


How can I replace the Do loop?










share|improve this question











$endgroup$




I have:



list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, 
{1, 0, 2, 2, 2, 4, 0}}


I want to calculate the average but without considering the 0s.



The result should be:



Do[
array = list[[All, i]];
total = Total[array];
cnt = Count[array, 0];
result[[i]] = total/(Length@array - cnt);,
{i, 1, Length@result}
];

result // N

{2., 3., 3., 4., 4., 3., 9.}


How can I replace the Do loop?







list-manipulation






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 2 days ago









m_goldberg

87.4k872198




87.4k872198










asked 2 days ago









liolio

1,108217




1,108217








  • 1




    $begingroup$
    Mean /@ DeleteCases[Transpose@list, 0, All]
    $endgroup$
    – MarcoB
    2 days ago










  • $begingroup$
    Thank you for the solution.
    $endgroup$
    – lio
    2 days ago












  • $begingroup$
    You’re welcome. I’ve added an answer since this solution works for you
    $endgroup$
    – MarcoB
    2 days ago








  • 4




    $begingroup$
    I'm not at a computer right now, so please try Total[list]/Total[Unitize[list]].
    $endgroup$
    – J. M. is computer-less
    2 days ago










  • $begingroup$
    @J.M. Well, that is clever! Cool trick :-)
    $endgroup$
    – MarcoB
    2 days ago














  • 1




    $begingroup$
    Mean /@ DeleteCases[Transpose@list, 0, All]
    $endgroup$
    – MarcoB
    2 days ago










  • $begingroup$
    Thank you for the solution.
    $endgroup$
    – lio
    2 days ago












  • $begingroup$
    You’re welcome. I’ve added an answer since this solution works for you
    $endgroup$
    – MarcoB
    2 days ago








  • 4




    $begingroup$
    I'm not at a computer right now, so please try Total[list]/Total[Unitize[list]].
    $endgroup$
    – J. M. is computer-less
    2 days ago










  • $begingroup$
    @J.M. Well, that is clever! Cool trick :-)
    $endgroup$
    – MarcoB
    2 days ago








1




1




$begingroup$
Mean /@ DeleteCases[Transpose@list, 0, All]
$endgroup$
– MarcoB
2 days ago




$begingroup$
Mean /@ DeleteCases[Transpose@list, 0, All]
$endgroup$
– MarcoB
2 days ago












$begingroup$
Thank you for the solution.
$endgroup$
– lio
2 days ago






$begingroup$
Thank you for the solution.
$endgroup$
– lio
2 days ago














$begingroup$
You’re welcome. I’ve added an answer since this solution works for you
$endgroup$
– MarcoB
2 days ago






$begingroup$
You’re welcome. I’ve added an answer since this solution works for you
$endgroup$
– MarcoB
2 days ago






4




4




$begingroup$
I'm not at a computer right now, so please try Total[list]/Total[Unitize[list]].
$endgroup$
– J. M. is computer-less
2 days ago




$begingroup$
I'm not at a computer right now, so please try Total[list]/Total[Unitize[list]].
$endgroup$
– J. M. is computer-less
2 days ago












$begingroup$
@J.M. Well, that is clever! Cool trick :-)
$endgroup$
– MarcoB
2 days ago




$begingroup$
@J.M. Well, that is clever! Cool trick :-)
$endgroup$
– MarcoB
2 days ago










2 Answers
2






active

oldest

votes


















8












$begingroup$

Mean /@ DeleteCases[Transpose@list, 0, All]



{2,3,3,4,4,3,9}







share|improve this answer









$endgroup$





















    7












    $begingroup$

    I'm posting this as a CW answer, so J.M.'s very nice answer, made in a comment above, gets recorded as a real answer.



    list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, {1, 0, 2, 2, 2, 4, 0}};
    Total[list]/Total[Unitize[list]]



    {2, 3, 3, 4, 4, 3, 9}







    share|improve this answer











    $endgroup$













      Your Answer





      StackExchange.ifUsing("editor", function () {
      return StackExchange.using("mathjaxEditing", function () {
      StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
      StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
      });
      });
      }, "mathjax-editing");

      StackExchange.ready(function() {
      var channelOptions = {
      tags: "".split(" "),
      id: "387"
      };
      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: false,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: null,
      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%2fmathematica.stackexchange.com%2fquestions%2f192881%2faveraging-over-columns-while-ignoring-zero-entries%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









      8












      $begingroup$

      Mean /@ DeleteCases[Transpose@list, 0, All]



      {2,3,3,4,4,3,9}







      share|improve this answer









      $endgroup$


















        8












        $begingroup$

        Mean /@ DeleteCases[Transpose@list, 0, All]



        {2,3,3,4,4,3,9}







        share|improve this answer









        $endgroup$
















          8












          8








          8





          $begingroup$

          Mean /@ DeleteCases[Transpose@list, 0, All]



          {2,3,3,4,4,3,9}







          share|improve this answer









          $endgroup$



          Mean /@ DeleteCases[Transpose@list, 0, All]



          {2,3,3,4,4,3,9}








          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered 2 days ago









          MarcoBMarcoB

          37.4k556113




          37.4k556113























              7












              $begingroup$

              I'm posting this as a CW answer, so J.M.'s very nice answer, made in a comment above, gets recorded as a real answer.



              list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, {1, 0, 2, 2, 2, 4, 0}};
              Total[list]/Total[Unitize[list]]



              {2, 3, 3, 4, 4, 3, 9}







              share|improve this answer











              $endgroup$


















                7












                $begingroup$

                I'm posting this as a CW answer, so J.M.'s very nice answer, made in a comment above, gets recorded as a real answer.



                list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, {1, 0, 2, 2, 2, 4, 0}};
                Total[list]/Total[Unitize[list]]



                {2, 3, 3, 4, 4, 3, 9}







                share|improve this answer











                $endgroup$
















                  7












                  7








                  7





                  $begingroup$

                  I'm posting this as a CW answer, so J.M.'s very nice answer, made in a comment above, gets recorded as a real answer.



                  list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, {1, 0, 2, 2, 2, 4, 0}};
                  Total[list]/Total[Unitize[list]]



                  {2, 3, 3, 4, 4, 3, 9}







                  share|improve this answer











                  $endgroup$



                  I'm posting this as a CW answer, so J.M.'s very nice answer, made in a comment above, gets recorded as a real answer.



                  list = {{1, 3, 4, 5, 6, 0, 9}, {4, 0, 3, 5, 0, 2, 0}, {1, 0, 2, 2, 2, 4, 0}};
                  Total[list]/Total[Unitize[list]]



                  {2, 3, 3, 4, 4, 3, 9}








                  share|improve this answer














                  share|improve this answer



                  share|improve this answer








                  answered 2 days ago


























                  community wiki





                  m_goldberg































                      draft saved

                      draft discarded




















































                      Thanks for contributing an answer to Mathematica Stack Exchange!


                      • 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.


                      Use MathJax to format equations. MathJax reference.


                      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%2fmathematica.stackexchange.com%2fquestions%2f192881%2faveraging-over-columns-while-ignoring-zero-entries%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

                      Magento 2 - Add success message with knockout Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?Success / Error message on ajax request$.widget is not a function when loading a homepage after add custom jQuery on custom themeHow can bind jQuery to current document in Magento 2 When template load by ajaxRedirect page using plugin in Magento 2Magento 2 - Update quantity and totals of cart page without page reload?Magento 2: Quote data not loaded on knockout checkoutMagento 2 : I need to change add to cart success message after adding product into cart through pluginMagento 2.2.5 How to add additional products to cart from new checkout step?Magento 2 Add error/success message with knockoutCan't validate Post Code on checkout page

                      Fil:Tokke komm.svg

                      Where did Arya get these scars? Unicorn Meta Zoo #1: Why another podcast? Announcing the arrival of Valued Associate #679: Cesar Manara Favourite questions and answers from the 1st quarter of 2019Why did Arya refuse to end it?Has the pronunciation of Arya Stark's name changed?Has Arya forgiven people?Why did Arya Stark lose her vision?Why can Arya still use the faces?Has the Narrow Sea become narrower?Does Arya Stark know how to make poisons outside of the House of Black and White?Why did Nymeria leave Arya?Why did Arya not kill the Lannister soldiers she encountered in the Riverlands?What is the current canonical age of Sansa, Bran and Arya Stark?