another awk question


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting another awk question
# 1  
Old 03-10-2011
another awk question

file 1

Code:
 
000192602917 BL_db00p05d            10000000c9613ffc 071C  12F:0 Not Visible                7  (M)  92138 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ede 071C  12F:0 Not Visible                7  (M)  92138 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ffc 0728  03F:0 Not Visible                8  (M) 122850 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ede 0728  03F:0 Not Visible                8  (M) 122850 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ffc 0728  12F:0 Not Visible                8  (M) 122850 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ede 0728  12F:0 Not Visible                8  (M) 122850 BC_db00p05

File 2

Code:
 
071C,071C:2-Way
0728,0728:2-Way


Output needed

Code:
 
000192602917 BL_db00p05d            10000000c9613ffc 071C:2-Way  12F:0 Not Visible                7  (M)  92138 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ede 071C:2-Way  12F:0 Not Visible                7  (M)  92138 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ffc 0728:2-Way  03F:0 Not Visible                8  (M) 122850 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ede 0728:2-Way  03F:0 Not Visible                8  (M) 122850 BC_db00p05              
000192602917 BL_db00p05d            10000000c9613ffc 0728:2-Way  12F:0 Not Visible                8  (M) 122850 BC_db00p05

Basically compare the 4th column value of file1 to file 2 1st column value and replace it with the 2nd column value ..thx
# 2  
Old 03-10-2011
Try:
Code:
awk 'NR==FNR{split($1,x,",");a[x[1]]=x[2];next}{$4=a[$4]}1' file_2 file_1

# 3  
Old 03-10-2011
A light vary in logic

Code:
 
awk 'NR==FNR {sub(/,/," ");a[$1]=$2;next} { if($4 in a) {$4=a[$4];} } 1' file2 file1

# 4  
Old 03-15-2011
thanks guys , both solutions work

---------- Post updated at 11:45 AM ---------- Previous update was at 11:32 AM ----------

Have another one ...

File1
Code:
 
2917,`0722,RDF1+TDEV,90(6),33,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e
2917,`0781,RDF1+TDEV,100(5),33,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e


File2
Code:
 
2917,`0722,RDF1+TDEV,90(6),03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e
2917,`0781,RDF1+TDEV,100(5),03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e
2917,`03A2,2-way,44,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e
2917,`03A6,2-way,44,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e

Ouput needed
Code:
 
2917,`0722,RDF1+TDEV,90(6),33,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e
2917,`0781,RDF1+TDEV,100(5),33,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e
2917,`03A2,2-way,44,,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e
2917,`03A6,2-way,44,,03E:0_12E:0,10000000c96c4af3_10000000c96c6e88,BL_db00p01e


Basically we need to this
compare $7 from 1st file to $6 in 2nd
Append the line if $7 ( file1) = $6 (file2) but $2 (file1) != $2 (file2)

Also add a "," to replace a missing column in file2 to make sure the output file has same columns in all lines -- thx
# 5  
Old 03-15-2011
Quote:
Originally Posted by bartus11
Try:
Code:
awk 'NR==FNR{split($1,x,",");a[x[1]]=x[2];next}{$4=a[$4]}1' file_2 file_1

I like your solution but we should sub to get the OP required output.
Code:
awk 'NR==FNR{split($1,x,",");a[x[1]]=x[2];next}{sub($4,a[$4])}1' file2 file1

Smilie
# 6  
Old 03-15-2011
Thx Dan , Can u pls help out with the 2nd question i had ...
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

awk question : system output to awk variable.

Hi Experts, I am trying to get system output to capture inside awk , but not working: Please advise if this is possible : I am trying something like this but not working, the output is coming wrong: echo "" | awk '{d=system ("date") ; print "Current date is:" , d }' Thanks, (5 Replies)
Discussion started by: rveri
5 Replies

2. Homework & Coursework Questions

awk question.

Use and complete the template provided. The entire template must be completed. If you don't, your post may be deleted! 1. The problem statement, all variables and given/known data: im using ls -l | xargs | awk '{what ever files here}' im trying to get something that looks like this... (7 Replies)
Discussion started by: rontopia
7 Replies

3. UNIX for Dummies Questions & Answers

Basic awk question...getting awk to act on $1 of the command itself

I have a script problem that I am not able to solve due my very limited understanding of unix/awk. This is the contents of test.sh awk '{print $1}' From the prompt if I enter: ./test.sh Hello World I would expect to see "Hello" but all I get is a blank line. Only then if I enter "Hello... (2 Replies)
Discussion started by: JasonHamm
2 Replies

4. UNIX for Dummies Questions & Answers

awk question

Can anyone help with this this one liner: nawk -v RS='' '$1=$1' InputFile What I have in the file: 0.0013985457223116 -0.0002338180925628 0.0 0.0003709430584958 -0.0005763523138347 0.0 And the output I want: 0.0013985457223116 -0.0002338180925628 0.0 0.0003709430584958... (1 Reply)
Discussion started by: mookie123
1 Replies

5. UNIX for Dummies Questions & Answers

awk question

Hi, in the following script, what does " a=$0} END " mean ? do we need that ? Thanks awk '{a=$0} END {for (i=NR; i>=1; i--) print a}' file (3 Replies)
Discussion started by: james94538
3 Replies

6. Shell Programming and Scripting

Awk Question

How I can rid of the following presentation du -sk /u*/oradata/TEST/*.dbf |awk '{print total+=$1} 1.28003e+06 4.35109e+06 4.36134e+06 4.4535e+06 5.47752e+06 5.48777e+06 7.52554e+06 7.73036e+06 9.06158e+06 :confused: thank you (3 Replies)
Discussion started by: zam
3 Replies

7. Shell Programming and Scripting

awk question

I am trying to read through a file, gather the states in that file and change it from an abbreviation to the ful text. Can anyone provide some assistance. Thanks!! (4 Replies)
Discussion started by: cnitadesigner
4 Replies

8. Shell Programming and Scripting

awk .. question?

i have a little awk script that I use looks this: awk '{if (FNR==1){print FILENAME; print $0}else print $0}' file1...file2....fi... > bundled. i have completely forgotten how to unbundle this. I have tried several different approaches and still can not remember how to unbundle the file bundled.... (2 Replies)
Discussion started by: moxxx68
2 Replies

9. Shell Programming and Scripting

One more awk question!

Hello, I have the following command that does 2 searches. awk '{if ($0 ~ /STRING1/) {c++} }{if ( c == 2 ) {sub(/STRING1/,"NEWSTRING") } } { print }' FILE How do I search up after the first search? thanks (4 Replies)
Discussion started by: ctcuser
4 Replies

10. Shell Programming and Scripting

awk question

I have the following error: ls -lt | awk 'BEGIN NR > 1 { print $2, $9 }' Syntax Error The source line is 1. The error context is BEGIN >>> NR <<< > 1 { print $2, $9 } awk: 0602-500 Quitting The source line is 1. What I want to do is ls a directory, skip the first... (3 Replies)
Discussion started by: lesstjm
3 Replies
Login or Register to Ask a Question