Help with the awk syntax


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Help with the awk syntax
# 1  
Old 06-06-2013
Help with the awk syntax

Hello Experts:

While writing a script to help one of the posts on here, I end up writing a wrong one. I am very much eager to know how this can be corrected.
Aim was to not print specified columns - lets say out of 100 fields, need to print all but 5th, 10th, 15th columns.
Someone already answered it - $5=$10=$15="". This also should work.
I was thinking in another way to do it: Store the fields that needs to be excluded, in a separate file - nofields

Below is the script that I wrote:

awk 'NR==FNR{a[$1];next}{for (i = 1; i <= NF; i++)if(i not in a)print $i}' nofields input

I am sure there is mistakes in it, but interested in knowing what it is.

Last edited by juzz4fun; 06-06-2013 at 02:47 PM..
# 2  
Old 06-06-2013
Replace if(i not in a ) with if ( ! ( i in a ) )
This User Gave Thanks to Yoda For This Post:
# 3  
Old 06-06-2013
That certainly worked.
But the o/p is like 1st fields on 1st line, 2nd field on 2nd line, 3rd is on 3rd line so on..
how can I avoid this?
# 4  
Old 06-06-2013
Replace print $i with printf (i==NF?$i RS:$i)
# 5  
Old 06-06-2013
Quote:
Originally Posted by Yoda
Replace print $i with printf (i==NF?$i RS:$i)
What if the last field is the one to be excluded from the output?
This User Gave Thanks to elixir_sinari For This Post:
# 6  
Old 06-06-2013
Quote:
Originally Posted by juzz4fun
Hello Experts:

While writing a script to help one of the posts on here, I end up writing a wrong one. I am very much eager to know how this can be corrected.
Aim was not to print specified columns - lets say out of 100 fields, need to print all but 5th, 10th, 15th columns.
Someone already answered it - $5=$10=$15="". This also should work.
I was thinking in another way to do it: Store the fields that needs to be excluded, in a separate file - nofields

Below is the script that I wrote:

awk 'NR==FNR{a[$1];next}{for (i = 1; i <= NF; i++)if(i not in a)print $i}' nofields input

I am sure there is mistakes in it, but interested in knowing what it is.
Setting $5 $10 and $15 to null is the way to go but if you want to do it using an exclude file then here's how...
Code:
awk '{if (NR==FNR) a[$1]; else {for (i=1; i<=NF; i++) if (!(i in a)) printf("%s", i<NF ? $i FS : $i "\n")}' nofields input


Last edited by shamrock; 06-06-2013 at 03:03 PM.. Reason: Beaten by Yoda to the pip...
# 7  
Old 06-06-2013
Thanks all... I modified my script as below and it worked as expected.

nawk 'NR==FNR{a[$1];next}{for (i = 1; i <= NF; i++)if(!(i in a))printf("%s", i<NF ? $i FS : $i "\n")}' nofields input
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Awk: syntax error

awk -F, ' NR>1 { BEGIN{ chr=$2 } END{ for (k in chr) {print k} } } ' $gene_file I've a really simple code. I want to store gene name and it's chromosome and in the end print them. I'm skipping line one as it contains headers. But I don't know why I get error as: (2 Replies)
Discussion started by: genome
2 Replies

2. Shell Programming and Scripting

Syntax Problem with awk

Hello, I have perl script,which take some part of data in the file. the below command works fine in normal cmd prompt. `awk '/CDI/ && // && !/Result for/ {print $3 $5 > "final.txt"}' datalist.txt`; `nawk -F"" '{print $2}' finalcdi.txt`; But not working. Please use code tags, thanks. (5 Replies)
Discussion started by: rasingraj
5 Replies

3. Shell Programming and Scripting

AWK Function syntax

Hi, I would like to know what is the correct syntax to perform a function in awk. Although I have seen several examples, not get it to work, this is what I'm trying: #!/bin/bash awk function multi (number) { return number * 3 } print multi (4)Thanks (2 Replies)
Discussion started by: Godie
2 Replies

4. Shell Programming and Scripting

awk syntax

Hi I have a bash file which will split a big file to many small files. But I got a syntax error.H="$(head -1 CCC.tped)" awk 'print $0 > $1 ".tped"' CCC.tped for f in $(ls *.tped); do echo "$H\n" "$(cat $f)" >$f; done And -bash-4.1$ bash split awk: print $0 > $1".tped" awk: ^ syntax error... (3 Replies)
Discussion started by: zhshqzyc
3 Replies

5. AIX

Help with syntax using AWK

I have a file which is comma separated and has quotes. I can use this command and awk -F"," '{ if ($4=="01" print $0 }' test.txt But this doesn't fetch me the data.since it has quotes. If the data has no quotes,the above command works fine. In Unix you can skip quote \" but this doesn't work.... (7 Replies)
Discussion started by: ganesnar
7 Replies

6. Shell Programming and Scripting

AWK syntax help

i have a ksh code that needs to be written in AWK. can someone please help me here? :( if }" | grep -c "$2") -gt 0 ] ; then print - "found $2 in array ignore" else print - "did not find $2 in array ignore" fi ignore=4ty56r ignore=er45ty . . . ignore=frhtg2 (27 Replies)
Discussion started by: usustarr
27 Replies

7. UNIX for Dummies Questions & Answers

awk syntax

Little bit confusing while using awk :confused::confused: In Sed while pattern search we can use "(double quotes) i mean $a=hello $cat file.txt |sed -n "/$a/p"this thing work fine But if i use it in awk it's not working How could i do the substitution of pattern by a variables and the... (1 Reply)
Discussion started by: posix
1 Replies

8. Shell Programming and Scripting

AWK syntax

Hi I am trying to understand AWK syntax so I tried this command which gives me the home directory of root awk 'BEGIN { FS = ":"} {if ($1 == "root") print $6 }' /etc/passwd I would know what are the following commands doing. The first one prints all /etc/passwd, second prints nothing. ... (4 Replies)
Discussion started by: wakatana
4 Replies

9. Shell Programming and Scripting

awk syntax help

I don't get correct output when I run this command line: nmap -sP failedhost.com | grep -i failed | awk -F '{print $6}' I basically want it to return 'failedhost.com' but its just showing the output of the nmap scan. (8 Replies)
Discussion started by: streetfighter2
8 Replies

10. Shell Programming and Scripting

Help with Awk Syntax

I have written many awk commands which go in multiple lines. I have this confusion many times. Some time they work if i dont terminate them with "\" but some time error. Some time in "if" statements between if and else if i dont use ";" it gives error but sometimes it doesnt. The below... (4 Replies)
Discussion started by: pinnacle
4 Replies
Login or Register to Ask a Question