comparing two files using awk


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting comparing two files using awk
# 8  
Old 11-13-2010
You can further shorten your script like this:
Code:
awk 'FILENAME=="target" {arr[$1]++}
     FILENAME=="lookup" && !($1 in arr) {print $0}' target lookup > out

and then:
Code:
awk 'FILENAME=="target" {arr[$1]++}
     FILENAME=="lookup" && !($1 in arr)' target lookup > out

I used $1 instead of $0 so that there are no mismatches due to spacing differences..
# 9  
Old 11-13-2010
Quote:
Originally Posted by Scrutinizer
Welcome to the forum!
You can use the inverse:
Code:
awk 'FILENAME=="target" {arr[$0]++}
     FILENAME=="lookup" {if(!($0 in arr)) {print $0}}' target lookup


so just to read that back in my head

"if the value in $0 is not in the equiavalent array position, print said value"

where the exclamation mark represents the "not in" condition?
# 10  
Old 11-13-2010
@#9 : indeed
# 11  
Old 11-13-2010
Quote:
Originally Posted by Scrutinizer
You can further shorten your script like this:
Code:
awk 'FILENAME=="target" {arr[$1]++}
     FILENAME=="lookup" && !($1 in arr) {print $0}' target lookup > out

and then:
Code:
awk 'FILENAME=="target" {arr[$1]++}
     FILENAME=="lookup" && !($1 in arr)' target lookup > out

I used $1 instead of $0 so that there are no mismatches due to spacing differences..

interesting. how comes the former doesnt print on screen first despite the print $0?

having trouble reading back the red bit. what are we doing here?
# 12  
Old 11-13-2010
It does not print on screen because of the redirect of stdout of awk to the file "out" (> out)
The red part makes use of the fact that {print $0} is the default action in awk so you can leave that out.
# 13  
Old 11-13-2010
makes sense. enhancing it further to allow user to provide a path for the target file. was pretty simple and got that working.

Code:
echo 'enter full path to eodfeed file'
read targetpath
echo $targetpath
awk '
FILENAME=="$targetpath" {arr[$1]++}
FILENAME=="lookup" && !($1 in arr) ' $targetpath lookup > out

now id like to offer the user to provide the path of a file that itself contains multiple paths to target files. the script would then lookup against each target file in a loop and save the results to a separate output file (which would be conveniently named after the target file the lookup was carried against)

so the user would provide the location of a file that contains the following
/opt/ice/server/targetfile1
/opt/ice/server/targetfile2
/opt/ice/server/targetfile3

the script would use "lookup" file against each one of the above and output the results as
out_targetfile1
out_targetfile2
out_targetfile3

before i have a crack at it, im trying to figure out where id start
i guess the first thing is to read the file the user has provided and store the 3 locations into an array (this is within the awk). start a for loop, for each i in arr do <awk program that already works>

on the right tracks?
# 14  
Old 11-13-2010
The code in #13 will not work IMO, since $targetpath does not get evaluated inside the ' '
But I think we can leave targetpath out entirely if we use a next statement:
Code:
awk ' FILENAME=="lookup" && !($1 in arr){print; next} {arr[$1]++} ' "$targetpath" lookup

Now using the user provided file that contains the target, I would get the targetfile from the user and then I would just use this code in a while-read loop in the shell :
Code:
while read file
do
   if [ -r "$file" ]; then
     awk ' FILENAME=="lookup" && !($1 in arr){print; next} {arr[$1]++} ' "$file" lookup > "$file.out"
   fi
done < "$targetfile"

Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. UNIX for Dummies Questions & Answers

Comparing two txt files with AWK

Hi, I need to compare two text files with awk. File1: ------- chr1 43815007 43815009 COSM19193 REF=TG;OBS=AA;ANCHOR=G AMPL495041 chr1 43815008 43815009 COSM18918 REF=G;OBS=T;ANCHOR=T AMPL495041 chr1 115256527 115256528 ... (6 Replies)
Discussion started by: RushiK
6 Replies

2. Shell Programming and Scripting

awk for comparing two files

so have file1 like this: joe 123 jane 456 and then file2 like this: 123 left right 456 up down joe ding dong jane flip flop what I need to do is compare col1 and col2 in file1 with col1 in file2 and generate a new file that has lines like this: joe 123 ding dong left right jane... (11 Replies)
Discussion started by: Jaymz
11 Replies

3. Shell Programming and Scripting

Comparing the matches in two files using awk when both files have their own field separators

I've two files with data like below: file1.txt: AAA,Apples,123 BBB,Bananas,124 CCC,Carrot,125 file2.txt: Store1|AAA|123|11 Store2|BBB|124|23 Store3|CCC|125|57 Store4|DDD|126|38 So,the field separator in file1.txt is a comma and in file2.txt,it is | Now,the output should be... (2 Replies)
Discussion started by: asyed
2 Replies

4. Shell Programming and Scripting

comparing 2 files with awk

Hi, I'm a new user in awk and i'm trying to compare two files to create a third one if some values match in both files. The first file has this content: s 45.960746365 _21_ AGT 2490 [21:0 22:0 s 45.980418496 _21_ AGT 2491 [21:0 22:0 s 46.000090627 _21_ AGT 2492 [21:0 22:0 s 47.906552206... (2 Replies)
Discussion started by: carlosoria
2 Replies

5. UNIX for Advanced & Expert Users

Comparing two files using awk

i have one file say file1 having many records.Each record contains 2000 characters.i have to compare 192-200 (stored as name)characters in this file from other file say file2 having name stored in 1-9 characters. after comparing i have to print the record from file1 in another file say file3 ... (3 Replies)
Discussion started by: sonam273
3 Replies

6. Shell Programming and Scripting

Comparing 2 input files -Awk

Compare 2 files and print the values input1 (c1 20 100 X_y10) along with one closest highest (c1 100 200 X_y10) and one lowest values (c1 10 15 X_y10) from input2 input1 c1 20 100 X_y10 input2 c1 5 10 X_y10 c1 10 15 X_y10 c1 100 200 X_y10 c1 200 300 X_y10 output ... (8 Replies)
Discussion started by: bumblebee_2010
8 Replies

7. Shell Programming and Scripting

comparing files with field using awk

hi, i have 1 files a.csv temp.out a.cvs looks like add,16390,180,674X,HALIFAX_COMMONS_X,902,497,902-209 add,16390,180,674X,HALIFAX_COMMONS_X,902,497,902-219 add,16390,180,674X,HALIFAX_COMMONS_X,902,497,902-220 add,16390,180,674X,HALIFAX_COMMONS_X,902,497,902-221 and temp.out looks... (1 Reply)
Discussion started by: raghavendra.cse
1 Replies

8. Shell Programming and Scripting

awk - comparing files

I've been trying to use awk to compare two files that have pretty much the same data in apart from certain lines where in one file a fields value has changed. I want to print the line from the first file and the changed line from the second file. At the moment, all I can get it to do is print the... (6 Replies)
Discussion started by: dbrundrett
6 Replies

9. Shell Programming and Scripting

Comparing two files using awk

Hi, I have 2 text files n1 and n2. cat n1 : -------- 1234567890 4444444444 cat n2 : --------- 1234567890 4444444444 7777777777 8888888888 they are some sample records. File n1 contains some lookup records, whereas file n2 contains some transaction records. I need to get the... (2 Replies)
Discussion started by: kanu_kanu
2 Replies

10. Shell Programming and Scripting

comparing two files using awk.

Hi All, a new bie to awk, How to compare substring of col1,file 1 with col2file2 and get file1contents+col3file2 as output. file1 ----- kumarfghh,23,12000,5000 rajakumar,24,14000,2500 rajeshchauhan,25,16000,2600 manoj,26,17000,2300 file 2 -------- 123,kumar,US, 123,sukumar,UK... (4 Replies)
Discussion started by: jerome Sukumar
4 Replies
Login or Register to Ask a Question