Print column details from fixed width file using awk command


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Print column details from fixed width file using awk command
# 1  
Old 12-26-2014
Print column details from fixed width file using awk command

hi,

i have a fixed width file with multiple columns and need to print data using awk command.
i use:
Code:
awk -F "|" '($5 == BH) {print $1,$2,$3}' <non_AIM target>.txt

for a delimiter file.
but now i have a fixed width file like below:
Code:
7518   8269511BH 20141224951050N8262
11148  8269511BH 20141224951050N8262
11718  8269511BH 20141224951050N8262

Fixed width column wise lengths: 7,3,3,1,2,11,8,3,3,1,3,1
Could u pls help me to fetch data for rows with col5 as 'BH' value

I am new to awk coomands.
Appreciate ur help in advance

Moderator's Comments:
Mod Comment Please post in the proper forum

Last edited by Scrutinizer; 12-26-2014 at 11:33 AM.. Reason: CODE tags
This User Gave Thanks to kcdg859 For This Post:
# 2  
Old 12-26-2014
Try GNU awk:
Code:
awk '$5=="BH"' FIELDWIDTHS="7 3 3 1 2 11 8 3 3 1 3 1" file

or regular awk:
Code:
awk 'substr($0,15,2)=="BH"'

or
Code:
sed '/^.\{14\}BH/!d' file

This User Gave Thanks to Scrutinizer For This Post:
# 3  
Old 12-26-2014
What is i have to fetch only particular columns like $1,$2 with an extra condition like $5='BH' and $1=7518

Thanks for your quick reply.
# 4  
Old 12-26-2014
Try (GNU awk) :
Code:
awk '$5=="BH" && $1==7518{print $1, $2}' FIELDWIDTHS="7 3 3 1 2 11 8 3 3 1 3 1" file

This User Gave Thanks to Scrutinizer For This Post:
# 5  
Old 12-26-2014
Might also be of some interest:
Code:
awk '$15$16=="BH" && $1$2$3$4=="7518" {print $1$2$3$4$5$6$7$8$9$10}' FS="" file4
7518   826

# 6  
Old 12-26-2014
Note: an empty FS to make each individual character a separate field is supported by GNU awk, mawk and BSD awk, but it is not POSIX-compliant and therefore not universally supported..

Last edited by Scrutinizer; 12-27-2014 at 05:05 AM..
This User Gave Thanks to Scrutinizer For This Post:
Login or Register to Ask a Question

Previous Thread | Next Thread

9 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

UNIX command -Filter rows in fixed width file based on column values

Hi All, I am trying to select the rows in a fixed width file based on values in the columns. I want to select only the rows if column position 3-4 has the value AB I am using cut command to get the column values. Is it possible to check if cut -c3-4 = AB is true then select only that... (2 Replies)
Discussion started by: ashok.k
2 Replies

2. Shell Programming and Scripting

Replace using awk on fixed width file.

All, I used to use following command to replace specific location in a fixed width file. Recently looks like my command stopped working as intended. We are on AIX unix. awk 'function repl(s,f,t,v) { return substr(s,1,f-1) sprintf("%-*s", t-f+1, v) substr(s,t+1) } NR<=10 {... (3 Replies)
Discussion started by: pinnacle
3 Replies

3. Shell Programming and Scripting

To replace the value of the column in a fixed width file

I have a fixed with file with header & trailer length having the same length of the detail record file. The details record length of this file is 24, for Header and Trailer the records will be padded with spaces to match the record length of the file Currently I am adding 3 spaces in header... (14 Replies)
Discussion started by: ginrkf
14 Replies

4. Shell Programming and Scripting

How to split a fixed width text file into several ones based on a column value?

Hi, I have a fixed width text file without any header row. One of the columns contains a date in YYYYMMDD format. If the original file contains 3 dates, I want my shell script to split the file into 3 small files with data for each date. I am a newbie and need help doing this. (14 Replies)
Discussion started by: bhanja_trinanja
14 Replies

5. UNIX for Dummies Questions & Answers

Remove duplicates based on a column in fixed width file

Hi, How to output the duplicate record to another file. We say the record is duplicate based on a column whose position is from 2 and its length is 11 characters. The file is a fixed width file. ex of Record: DTYU12333567opert tjhi kkklTRG9012 The data in bold is the key on which... (1 Reply)
Discussion started by: Qwerty123
1 Replies

6. Shell Programming and Scripting

Changing one column of delimited file column to fixed width column

Hi, Iam new to unix. I have one input file . Input file : ID1~Name1~Place1 ID2~Name2~Place2 ID3~Name3~Place3 I need output such that only first column should change to fixed width column of 15 characters of length. Output File: ID1<<12 spaces>>Name1~Place1 ID2<<12... (5 Replies)
Discussion started by: manneni prakash
5 Replies

7. Shell Programming and Scripting

edit entire column from a fixed-width file using awk or sed

Col1 Col2 Col3 Col4 12 Completed 08 0830 12 In Progress 09 0829 11 For F U 07 0828 Considering the file above, how could i replace the third column the most efficient way? The actual file size is almost 1G. I am... (10 Replies)
Discussion started by: tamahomekarasu
10 Replies

8. Shell Programming and Scripting

Comparing column of variable length anf fixed width file

Hi, I have two input files. File1: ID Name Place 1-234~name1~Newyork 1-34~name2~Boston 1-2345~name3~Hungary File1 is a variable length file where each column is seperated by delimitter "~". File2: ID Country 1-34<<11 SPACES>>USA<<7 spaces>> 1-234<<10 SPACES>>UK<<8... (5 Replies)
Discussion started by: manneni prakash
5 Replies

9. UNIX for Dummies Questions & Answers

Fixed Width file using AWK

I am using the following command at the Unix prompt to make my 'infile' into a fixed width file of 100 characters. awk '{printf "%-100s\n",$0}' infile > outfile However, there are some records with a special character "©" These records are using 3 characters in place of one and my record... (2 Replies)
Discussion started by: alok.benjwal
2 Replies
Login or Register to Ask a Question