awk for loop help


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting awk for loop help
# 1  
Old 01-23-2015
awk for loop help

Hello,
I have an input file that looks like so:

Code:
 1 2 3
4 5 6
7 8 9

and I just want to print the first and third column (note: my actual file contains many many more fields so I don't want to use '{ print $NF }' for each field I want.

I tried using:
Code:
awk 'BEGIN {FS=" "} { for (i=1; i<=NF; i++) if (i<2 || i>2) print $i }' input.txt

but I do not get the output I want.

Any help is appreciated, Thank you.
# 2  
Old 01-23-2015
Hello.

Me no understand.

If you want the first and third columns, why not use $1 and $3, instead of a for-loop?

Code:
$ echo "1 2 3
> 4 5 6
> 7 8 9" | awk '{print $1, $3}'
1 3
4 6
7 9
$

There's a bunch of other stuff to consider. Such as, the "input" you show starts with a leading space (presumably it's a space), and you set the field separator to a space, which means "1" would be the second field. Also, if you want the 1st and 3rd fields, $NF has no role to play. Also, you say the input file "looks like this", then proceed to claim that actually, it doesn't, etc.
# 3  
Old 01-23-2015
Hi,
What I meant was that my actual file has the same format, but is much larger. It contains many more fields. I just put in three for the sake of simplicity.

There should be no space at the beginning, it should look like:

Code:
1 2 3
4 5 6
7 8 9

Again, my actual file contains many fields that are space separated, not just three. Thats why I wanted to use the for loop.
# 4  
Old 01-23-2015
Hi.

That's fine.

But it's the same answer: if you want to extract specific fields, just use the field numbers. There's no need for a loop.

Code:
awk '{ print $1, $3 }' file

The tab and the space are the default field separators, so there is no need to set FS if your file is space-separated (doing so (FS=" ") would mean every space adds a new field).



edit: Actually, that ("(doing so (FS=" ") would mean every space adds a new field)") is not true, at least in GNU Awk
Code:
(two spaces between A, B and C...)
$ echo "A  B  C" | awk -F" " '{print $1, $2}'
A B
$ echo "A  B  C" | cut -d" " -f1,2
A


Last edited by Scott; 01-23-2015 at 03:26 PM.. Reason: edit
# 5  
Old 01-23-2015
Try this as a starting point:
Code:
awk 'NR==1  {MX=split(COLS,C)} {for (i=1; i<=MX; i++) printf "%s ", $(C[i]); printf "\n"}' COLS="1 3" file
1 3 
4 6 
7 9

# 6  
Old 01-23-2015
As with many of Rabu's threads, the problem specification isn't really clear.

Scott is absolutely correct that a for loop is not needed with the specified problem (and would be inefficient if the goal really is to always print the 1st and 3rd fields from every input line).

But, if the real goal is to print every field except the 2nd field, then a for loop makes sense. But using print instead of printf (without a \n in the format string) would create separate lines for each printed field instead the desired single line of output.

Scott,
The latest update to the POSIX standards says this about a single character ERE being used for FS:
Quote:
2. If FS is a single character:
  1. If FS is <space>, skip leading and trailing <blank> and <newline> characters; fields shall be delimited by sets of one or more <blank> or <newline> characters.
  2. Otherwise, if FS is any other character c, fields shall be delimited by each single occurrence of c.
Note that this is why FS="." and FS="*"work without needing to use FS="[.]" or FS="\*" when the goal is use a period or asterisk as a field separator without having to worry about them being interpreted as a metacharacters. But, if you want to use period and asterisk as field separators you need something like FS="[.]|[*]" instead of just FS=".|*".

Rabu,
Since {print $1,$3} does exactly what you have requested, please clearly explain why you don't want to use it (or clarify what you are trying to do so we understand why this code is not the best solution for your problem).
This User Gave Thanks to Don Cragun For This Post:
# 7  
Old 01-23-2015
Don Cragun, you sir, are awesome.
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