While-loop with awk


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting While-loop with awk
# 8  
Old 08-28-2007
Quote:
Originally Posted by baghera
Huh? I tried your script but I only get 1.5

when I have list:

1
2
1
2

The output should be:
1
2

Or on the same row 1 2

As I described above. But there should also be the possibility to tell how many columns there should be.
I guess I still don't understand something.....
You're trying to calculate the average per column. The column average is: sum of the cells DIVIDED by the number of rows.
In your example you have ONE column and 4 rows:
Code:
1
2
1
2

the sum is: 6
# of rows: 4
------------
avg = (6/4) = 1.5

I must be missing something obvious......
# 9  
Old 08-28-2007
Sorry maybe I'm not made my self clear. So I will explain.

I've a list in a file that looks like this:

1
2
1
2

What I want to do is to tell my script how many columns I would like. So if I want, let's say, 2 columns it would look like this:
1 2
1 2

And then I would like to add each element in a column and divide it by the number of elements in that column and then print out the average. So my output should be in the case above:

1 2

Where 1 is the average value of column 1 and 2 is the average value of column 2.

And I should add that I'm using Solaris 9 and awk is the only command available to me.
# 10  
Old 08-28-2007
ok, NOW I think I understand:

# this will split it into '2' columns and do the avg - '2' is the default # of columns
nawk -f bag.awk myList

# this will split it into '3' columns and do the avg
nawk -v n=3 -f bag.awk myList
bag.awk:
Code:
BEGIN {
    n=(n=="") ? 2 : n
}
{
   idx=(FNR%n) ? FNR%n  : n
   sum[idx] += $0
   nf=(idx>nf) ? idx : nf
   nr=((FNR%n) == 1) ? nr+1 : nr
}

END {
    for(i=1; i<=nf; i++)
        printf("%s%s", sum[i]/nr, (i==nf) ? "\n" : OFS)
}


Last edited by vgersh99; 08-28-2007 at 04:12 PM.. Reason: fixed the 'nr' pivot
# 11  
Old 08-28-2007
Quote:
Originally Posted by vgersh99
ok, NOW I think I understand:

# this will split it into '2' columns and do the avg - '2' is the default # of columns
nawk -f bag.awk myList

# this will split it into '3' columns and do the avg
nawk -v n=3 -f bag.awk myList
bag.awk:
Code:
BEGIN {
    n=(n=="") ? 2 : n
}
{
   idx=(FNR%n) ? FNR%n  : n
   sum[idx] += $0
   nf=(idx>nf) ? idx : nf
   nr=((FNR%n) == 1) ? nr+1 : nr
}

END {
    for(i=1; i<=nf; i++)
        printf("%s%s", sum[i]/nr, (i==nf) ? "\n" : OFS)
}

Works like a charm, thank you. But if the input should come from another command, how would that look like?

output | awk -v n=2 -f bag.awk

Would the above work? Because the input isn't always a file, sometimes it is a computation from a previous command. But your script was the first I got to work without any fuss.
# 12  
Old 08-28-2007
you got it - that's the syntax.
# 13  
Old 08-29-2007
I wonder why I have to use nawk when sitting in Solaris 9, since it seems to have both awk and nawk?

>>which awk
/usr/bin/awk

>>which nawk
/usr/bin/nawk


Because at home I used awk for the script vgersh99 gave me sitting on Mac OS X (latest version 10.4.xx), but when using a friends Solaris 9, I have to use nawk.

What is the difference? And why does it seem to work with awk on Mac OS X and only with nawk on Solaris ?

Just interested to know the difference for future knowledge.
# 14  
Old 08-29-2007
Solaris' '/usr/bin/awk' is an acient broken implementation of 'awk'. The prefered awk version on solaris is either '/usr/bin/nawk' or a POSIX-complient implementation under '/usr/xpg4/bin/awk' (or 'gawk' if you have one).
Here's the AWK Compatibility List.
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. UNIX for Beginners Questions & Answers

awk !seen[$]++ in else loop

Hi all, I was searching the net for a solution for my problem... unfortunately nothing so far. I want to sort on more than on column tab delimited file and keep the line if in the column I sort there is no value, but for those who have a value I want them only unique. I have tried the... (5 Replies)
Discussion started by: ksenia
5 Replies

2. UNIX for Beginners Questions & Answers

awk with For loop

Hi My Requirement is to take the sum of each column below is the input file. 1 2 3 4 1 2 3 4 1 2 3 4 Initial i was using below command to achieve my desired result. however this was adding the row and not column. i am not able understand why this is happening awk... (1 Reply)
Discussion started by: scriptor
1 Replies

3. Shell Programming and Scripting

awk programming -Passing variable to awk for loop

Hi All, I am new to AWK programming. I have the following for loop in my awk program. cat printhtml.awk: BEGIN -------- <some code here> END{ ----------<some code here> for(N=0; N<H; N++) { for(M=5; M<D; M++) print "\t" D ""; } ----- } ... (2 Replies)
Discussion started by: ctrld
2 Replies

4. Shell Programming and Scripting

awk loop using array:wish to store array values from loop for use outside loop

Here's my code: awk -F '' 'NR==FNR { if (/time/ && $5>10) A=$2" "$3":"$4":"($5-01) else if (/time/ && $5<01) A=$2" "$3":"$4-01":"(59-$5) else if (/time/ && $5<=10) A=$2" "$3":"$4":0"($5-01) else if (/close/) { B=0 n1=n2; ... (2 Replies)
Discussion started by: klane
2 Replies

5. Shell Programming and Scripting

awk loop and using shell in awk

Hi, everyone! I have a file, when I print its $1 out it show several strings like this: AABBCC AEFJKLFG FALEF FAIWEHF What I want to do is that, after output of each record, search the string in all files in the same folder, print out the record and file name. This is what I want... (4 Replies)
Discussion started by: xshang
4 Replies

6. Shell Programming and Scripting

awk - loop from a to z

Hello, I was wondering if it is possible to do a loop on letters rather than numbers with awk (gawk). Basically I used to do: echo "nothing" | gawk '{for(i=1;i<11;i++)print i}' But I would like to do something like that (which obviously does not work): echo "nothing" | gawk '{for(i in... (6 Replies)
Discussion started by: jolecanard
6 Replies

7. Shell Programming and Scripting

Comparison and editing of files using awk.(And also a possible bug in awk for loop?)

I have two files which I would like to compare and then manipulate in a way. File1: pictures.txt 1.1 1.3 dance.txt 1.2 1.4 treehouse.txt 1.3 1.5 File2: pictures.txt 1.5 ref2313 1.4 ref2345 1.3 ref5432 1.2 ref4244 dance.txt 1.6 ref2342 1.5 ref2352 1.4 ref0695 1.3 ref5738 1.2... (1 Reply)
Discussion started by: linuxkid
1 Replies

8. Shell Programming and Scripting

awk for-loop and NR

Hey, I know this is a stupid question, but it doesn't work. I have a file with 10 lines and I want to pipe the content to awk and then print line 1 til 2 into another file and then line 3-4 ... So my script looks like that, but doesn't work: cat grid_ill.pts | awk '{ for (NR=1;NR<3;NR++)... (8 Replies)
Discussion started by: ergy1983
8 Replies

9. UNIX for Dummies Questions & Answers

for loop in awk?

I am new to unix and have pieced together two scripts that work independently. The first checks all the filesystems and reports which are running low on space. df -m | awk 'int($4) > 75 { print $1 " has only " $3 "mb free from a total of " $2 ", this filesystem is " $4 " full! \n" }... (1 Reply)
Discussion started by: Bdawk
1 Replies

10. Shell Programming and Scripting

Using AWK in a for loop

Hello, I am trying to use AWK to print only the first field of numerous text files, and then overwrite these files. They are of the format 1*2,3,4,5. I have tried the following code (using tcsh): foreach f (file1 file2 file3) cat $f | awk -F'*' '{print $1}' > $f end However, I get very... (4 Replies)
Discussion started by: Jahn
4 Replies
Login or Register to Ask a Question