awk for loop help


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting awk for loop help
# 8  
Old 01-23-2015
Hi Don and Scott,

I apologize for not clearly stating the problem, but say my actual input file contained 14 fields, and I only wanted to print all fields except for 6 and 7. Wouldn't a for loop be better suited to printing the fields I want instead of typing each individual field number?

I am still quite new to bash and awk, so please forgive any lapses in clarification.

Thanks to both of you.
# 9  
Old 01-23-2015
Untested (since you didn't provide any sample input and output), but pretty simple:
Code:
awk '
{	for(i = 1; i < 6; i++)
		printf("%s ", $i)
	for(i = 8; i < 14; i++)
		printf("%s ", $i)
	print $14
}' file

or:
Code:
awk '
{	for(i = 1; i <= NF; i++)
		if(i != 6 && i != 7)
			printf("%s%s", $i, (i == NF) ? "\n" : " ")
}' file

# 10  
Old 01-23-2015
Try
Code:
awk 'NR==1  {MX=split(COLS,C)} {for (i=1; i<=MX; i++) $(C[i])=""; $0=$0; $1=$1}1' COLS="6 7" file

This User Gave Thanks to RudiC For This Post:
# 11  
Old 01-24-2015
Or perhaps just:
Code:
awk '{$6=$7=x; $0=$0; $1=$1}1'  file

# 12  
Old 01-25-2015
Quote:
Originally Posted by RudiC
Try
Code:
awk 'NR==1  {MX=split(COLS,C)} {for (i=1; i<=MX; i++) $(C[i])=""; $0=$0; $1=$1}1' COLS="6 7" file

Hi RudiC,

the code works.
one thing I don't understand is:
Code:
$0=$0; $1=$1

I know
Code:
$1=$1

is to rebuild the line with default one space.
what's "$0=$0; $1=$1" mean?
# 13  
Old 01-26-2015
man awk:
Quote:
Assignment to $0 causes the fields and NF to be recomputed. Assignment to NF or to a field causes $0 to be reconstructed by concatenating the $i's separated by OFS.
# 14  
Old 01-26-2015
Quote:
Originally Posted by RudiC
man awk:
Thanks RudiC.

Smilie
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