Sponsored Content
Top Forums Shell Programming and Scripting IF awk in a while read line-loop Post 302643235 by IMPe on Friday 18th of May 2012 06:39:36 PM
Old 05-18-2012
im still trying to bring two files together. After i clean up my files the pasting line by line according to the date and time field is not working. The Fieldsep is TAB

here again what i want with the original data.
file1
Code:
05/15/12-12:40  7.82    305.30  0.09
05/15/12-12:50  8.38    295.85  0.01
05/15/12-13:00  8.04    298.16  0.01
05/15/12-13:10  9.05    301.95  0.00
05/15/12-13:20  8.09    303.94  0.00
05/15/12-13:30  7.87    314.60  1.13

file2
Code:
05/15/12-12:40  38685   3501    4346    5054    5017    4542    3805    3191    2908    2547    2413    2223    2027    1733    1448    1186    965     788     652     574     507     463     521     468     288     189     115     91      68      39      30      30      19      10      8       4       3       2       0       0       0       0       0       0       0       0       0       1       0       0       0       0       219     978.5   4.99    4       75      56.5    24.6
05/15/12-12:50  44343   3909    5024    5693    5837    4995    3905    3058    2486    2244    2094    1858    1635    1334    1143    908     747     676     533     485     440     395     455     357     267     148     122     132     84      42      28      21      14      11      4       2       5       2       1       1       1       0       1       0       0       1       0       0       0       1       0       0       224     977.3   5.01    4.02    75      55.9    22.2
05/15/12-13:00  41933   3641    4786    5776    5819    5300    4019    2880    2352    2060    1863    1645    1473    1218    1075    862     670     560     524     443     439     397     404     388     254     201     130     133     68      53      37      15      13      15      4       5       5       2       1       1       0       0       3       0       1       2       1       1       1       1       0       0       213     977.3   4.98    3.99    75      55.4    20.7
05/15/12-13:10  49477                                                                   568     494     480     464     471     374     225     185     168     135     80      45      29      20      8       7       8       3       2       1       0       0       0       0       1       0       0       2       0       0       0       0       0       252     977.3   5       3.99    75      55.1    19.7
05/15/12-13:30  67053   6218    8243    9898    9918    8450    6147    4173    3000    2363    2181    1948    1639    1461    1315    1068    917     769     666     589     534     483     505     565     436     257     181     150     125     59      36      23      15      11      3       1       3       0       0       1       1       0       0       0       0       0       0       0       0       0       0       0       324     977.5   4.99    3.99    75      54.8    19.7

and it should be
Code:
05/15/12-12:40  7.82    305.30  0.09 38685   3501    4346    5054    5017    4542    3805    3191    2908    2547    2413    2223    2027    1733    1448    1186    965     788     652     574     507     463     521     468     288     189     115     91      68      39      30      30      19      10      8       4       3       2       0       0       0       0       0       0       0       0       0       1       0       0       0       0       219     978.5   4.99    4       75      56.5    24.6
05/15/12-12:50  8.38    295.85  0.01 44343   3909    5024    5693    5837    4995    3905    3058    2486    2244    2094    1858    1635    1334    1143    908     747     676     533     485     440     395     455     357     267     148     122     132     84      42      28      21      14      11      4       2       5       2       1       1       1       0       1       0       0       1       0       0       0       1       0       0       224     977.3   5.01    4.02    75      55.9    22.2
05/15/12-13:00  8.04    298.16  0.01 41933   3641    4786    5776    5819    5300    4019    2880    2352    2060    1863    1645    1473    1218    1075    862     670     560     524     443     439     397     404     388     254     201     130     133     68      53      37      15      13      15      4       5       5       2       1       1       0       0       3       0       1       2       1       1       1       1       0       0       213     977.3   4.98    3.99    75      55.4    20.7
05/15/12-13:10  9.05    301.95  0.00 49477                                                                   568     494     480     464     471     374     225     185     168     135     80      45      29      20      8       7       8       3       2       1       0       0       0       0       1       0       0       2       0       0       0       0       0       252     977.3   5       3.99    75      55.1    19.7
05/15/12-13:20  8.09    303.94  0.00 
05/15/12-13:30  7.87    314.60  1.13  67053   6218    8243    9898    9918    8450    6147    4173    3000    2363    2181    1948    1639    1461    1315    1068    917     769     666     589     534     483     505     565     436     257     181     150     125     59      36      23      15      11      3       1       3       0       0       1       1       0       0       0       0       0       0       0       0       0       0       0       324     977.5   4.99    3.99    75      54.8    19.7

i tried to solve it with ygemici awk-array-construct but it will not work. --> awk: line 5: illegal reference to array b
Code:
awk -F'[:\t]' 'NR==FNR{cc=NR;s="\t";f=":";x++;
a[x]=$1f$2;;for(i=4;i<=NF;i++)a[x]=a[x]s$i}
NR!=FNR{c=0;for(i=1;i<=x;i++){
split(a[i],b,s);if($1f$2==b[1]){printf "%s",b[1]s$3s$4s;
for(j=2;j<=length(b);j++)printf "%s%c",b[j],s;printf "%s","\n"}
else c++};if(c==cc)print}' file2 file1

i need some help to solve it finally!
Thanks in advance!
IMPe

Last edited by IMPe; 05-18-2012 at 07:46 PM..
 

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Nested while read line loop

Hi, Can anyone please help me: i'm trying to read a file with directory-names , then go to that directory and read another (output) file to perform some tasks per line (second read line in the part of script below). The problem is that after the nested while loop has finished, the first while... (7 Replies)
Discussion started by: Rakker
7 Replies

2. UNIX for Dummies Questions & Answers

Alternative for a while read line loop

HELLO all :), I have been trying to use a simple while loop to read a file " templist", line by line and perform an action. See the code below. The reason for not using a while read line loop is the for the use of the if condition that wouldn't work. I would appreciate some ideas as this has... (2 Replies)
Discussion started by: kabs
2 Replies

3. Shell Programming and Scripting

read line in a for loop

Hi All, How can we use read line using the index value of a FOR loop? eg: pt_mstr,pt_status,8 pt_mstr,pt_buyer,8 pt_mstr,pt_sfty_stk,8 pt_mstr,pt_ord_pol,3 pt_mstr,pt_capacity,8 pt_mstr,pt_plan_ord,3 pt_mstr,pt_ord_mult,8 From this file i want to read the line2, 3 and 4 only using a FOR... (3 Replies)
Discussion started by: balajim
3 Replies

4. Shell Programming and Scripting

While read line loop

Hi I'm writing a bash script which will read an input file and look for occurrences of the current user ($USER) executing the script. When i find the occurrence of the username I take that line and append it to a file with a line number and bracket display next to line. The input file has been... (12 Replies)
Discussion started by: BundBash
12 Replies

5. Shell Programming and Scripting

While loop read line Issue

Hi I am using while loop, below, to read lines from a very large file, around 400,000 rows. The script works fine until around line 300k but then starts giving incorrect result. I have tried running the script with a smaller data set and it works fine. I made sure to include the line where... (2 Replies)
Discussion started by: saurabhkumar198
2 Replies

6. Shell Programming and Scripting

While loop read line not working

Hi, I am trying to read a file line by line inside of a while loop. This while loop is part of a here document. while read line do ssh -t $2@$remotehost <<REMOTE ls path/to/dir > $path_to_dir while read line1 do echo "LINE --- $line" done... (4 Replies)
Discussion started by: mnanavati
4 Replies

7. Shell Programming and Scripting

Read file using while loop not reading last line

I have written a script to read the file line by line. It is reading and printing the lines. But it is coming out of loop before reading last line. So I am not able to print last line. How do I solve it. (6 Replies)
Discussion started by: dgmm
6 Replies

8. Shell Programming and Scripting

Simple while read line loop question

#!/bin/bash count=1 while read line do if (($count > 4)); then awk -v var1="$count" '{printf "%3s%8s%11s%11s%11s\n",var1,$2,$3,$4,$5}' else echo $line fi count=$((count+1)) done < posre_sub.itp > test cat test INPUT: ; position restraints for... (3 Replies)
Discussion started by: origamisven
3 Replies

9. Shell Programming and Scripting

Do While Loop + Read From File + assign line to a variable

Hello, I am using below code for reading from a file and assigning the values to a variable , but it is loosing the value after the loop , please suggest to retain the value of the variable after the loop , while IFS=: read -r line do set $dsc=$line echo 'printing line variable ' $line... (1 Reply)
Discussion started by: ParthThakkar
1 Replies

10. Shell Programming and Scripting

While read line loop

Based on text file: PATH:/media/hdd/Media/Video/title1 FILE:/media/cache/281662-14.jpg PATH:/media/hdd/Media/Video/title2 FILE:/media/cache/281662-15.jpg PATH:/media/hdd/Media/Video/title3 FILE:/media/cache/281662-16.jpg PATH:/media/hdd/Media/Video/title4 FILE:/media/cache/281662-17.jpg... (12 Replies)
Discussion started by: TiedCone
12 Replies
All times are GMT -4. The time now is 01:50 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy