Solved

Sum Size Column From ls -la Command

Posted on 2011-09-19
10
474 Views
Last Modified: 2012-05-12
Partial listing of ls -la command.  I need a simple script that will sum up the size column .


-rw-r-----   1 oracle   oracle   31652864 Sep 19 13:21 1_124188_665266938.arc
-rw-r-----   1 oracle   oracle   44494848 Sep 19 13:36 1_124189_665266938.arc
-rw-r-----   1 oracle   oracle   32430080 Sep 19 13:51 1_124190_665266938.arc
-rw-r-----   1 oracle   oracle   92637184 Sep 19 14:06 1_124191_665266938.arc
-rw-r-----   1 oracle   oracle   92578304 Sep 19 14:13 1_124192_665266938.arc
-rw-r-----   1 oracle   oracle   60880384 Sep 19 14:28 1_124193_665266938.arc
-rw-r-----   1 oracle   oracle   37847040 Sep 19 14:43 1_124194_665266938.arc
-rw-r-----   1 oracle   oracle   46640640 Sep 19 14:58 1_124195_665266938.arc
-rw-r-----   1 oracle   oracle   73367552 Sep 19 15:13 1_124196_665266938.arc
-rw-r-----   1 oracle   oracle   95905280 Sep 19 15:22 1_124197_665266938.arc
0
Comment
Question by:xoxomos
  • 4
  • 2
  • 2
  • +1
10 Comments
 
LVL 12

Expert Comment

by:hfraser
ID: 36564055
If you're open to another command, "du -bc *" will produce a grand total. The "C" generates the total, and the "b" converts it from blocks to actual number of bytes similar to what the "ls -l" command produces.
0
 

Author Comment

by:xoxomos
ID: 36564133
Yes that's true.  Actually it was ls -la > somefile.  Once into somefile i eliminated some of the rows and I wanted to get the sum of that.  
Another alternative would be if i could do something like the du but only include those with the latest date(today)???
0
 
LVL 4

Assisted Solution

by:sakman
sakman earned 250 total points
ID: 36564243
There are many ways to go about this, including using the "du" command as hfraser mentioned.

If you want to continue putting your file listing into a file to process, you could do something like this:
$ ls -l /some/dir | grep 'Sep 19' >somefile
$ total=0
$ for size in `cat somefile | awk '{print $5}'`
> do
> total=`expr $total + $size`
> done
$ echo $total
608434176
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 12

Accepted Solution

by:
hfraser earned 250 total points
ID: 36564296
A simple awk script will tdo it for you.

{
  sum = sum + $5}
END {
 print sum
}

Just use cat filename | awk script.awk
0
 

Author Comment

by:xoxomos
ID: 36564346
Mil gracias everyone!!!
0
 
LVL 48

Expert Comment

by:Tintin
ID: 36564388
Much easer and quicker to do
ls -la | awk '{t+=$5} END {print t}'

Open in new window

0
 

Author Comment

by:xoxomos
ID: 36584067
sakman was most complete because this solution included ability to select a specific date :-)
Thanks
0
 
LVL 4

Expert Comment

by:sakman
ID: 36584096
IMHO, Tintin's solution is the most elegant - just add a grep for the date (depending on the date format of your system):

ls -la | grep 'Sep 19'  | awk '{t+=$5} END {print t}'

Open in new window

0
 

Author Comment

by:xoxomos
ID: 36584125
Yes.  Tintin always comes up with the most sexy solutions :-)  A bit late this time though :-(
0
 
LVL 48

Expert Comment

by:Tintin
ID: 36589952
With one less process :-)
ls -la | awk '/Sep 19/ {t+=$5} END {print t}'

Open in new window

0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I have been running these systems for a few years now and I am just very happy with them.   I just wanted to share the manual that I have created for upgrades and other things.  Oooh yes! FreeBSD makes me happy (as a server), no maintenance and I al…
I promised to write further about my project, and here I am.  First, I needed to setup the Primary Server.  You can read how in this article: Setup FreeBSD Server with full HDD encryption (http://www.experts-exchange.com/OS/Unix/BSD/FreeBSD/A_3660-S…
Learn how to get help with Linux/Unix bash shell commands. Use help to read help documents for built in bash shell commands.: Use man to interface with the online reference manuals for shell commands.: Use man to search man pages for unknown command…
This video shows how to set up a shell script to accept a positional parameter when called, pass that to a SQL script, accept the output from the statement back and then manipulate it in the Shell.

680 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question