Urgent: Help on grep the nearest value using bash script
Please support our Shell Scripting advertiser: Programming Forums
![]() |
•
•
Posts: 11
Reputation:
Solved Threads: 0
Hi,
I have a list of data in text files with :-
ColA ColB ColC ColD ColE ColF
12 122 2280 30 0.012987 1.776
13 118 2280 30 0.012987 1.954
14 115 2620 30 0.011321 2.131
15 113 2654 30 0.011177 2.309
16 145 1882 25 0.013110 2.487
17 112 2817 30 0.010537 2.664
18 126 2833 30 0.010479 2.842
19 111 2833 30 0.010479 3.020
16 145 1882 25 0.013110 2.487
17 112 2817 30 0.010537 2.664
How could I grep the nearest number to <=3.000 using bash script?
Means in the end i would like to isolate numbers in ColF which last seen the value <= 3.000 which is
18 126 2833 30 0.010479 2.842
Please help. Thanks.
I have a list of data in text files with :-
ColA ColB ColC ColD ColE ColF
12 122 2280 30 0.012987 1.776
13 118 2280 30 0.012987 1.954
14 115 2620 30 0.011321 2.131
15 113 2654 30 0.011177 2.309
16 145 1882 25 0.013110 2.487
17 112 2817 30 0.010537 2.664
18 126 2833 30 0.010479 2.842
19 111 2833 30 0.010479 3.020
16 145 1882 25 0.013110 2.487
17 112 2817 30 0.010537 2.664
How could I grep the nearest number to <=3.000 using bash script?
Means in the end i would like to isolate numbers in ColF which last seen the value <= 3.000 which is
18 126 2833 30 0.010479 2.842
Please help. Thanks.
Last edited by ahjiefreak : Apr 2nd, 2008 at 12:48 am. Reason: Confusion of the question
•
•
Posts: 399
Reputation:
Solved Threads: 47
Hey there,
This was bugging me all last night, and I finally figured out what my problem was
This should do the trick for you:
That gave me
2.842
from the text you pasted in this post. There's probably a more elegant solution out there, but this'll do the trick for now
Best wishes
, Mike
This was bugging me all last night, and I finally figured out what my problem was

This should do the trick for you:
awk 'BEGIN {var=3; highest=0}{ j = $NF;if ( j < var && j > highest ) { highest=j} } END {print highest}' YourInputFileThat gave me
2.842
from the text you pasted in this post. There's probably a more elegant solution out there, but this'll do the trick for now

Best wishes

, Mike
Linux and Unix Tips, Tricks and Individual Advice - The Linux and Unix Menagerie!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
•
•
Posts: 399
Reputation:
Solved Threads: 47
Actually, oops, you can change the
part to
just noticed that
, Mike
j < var
part to
j <= var
just noticed that

awk 'BEGIN {var=3; highest=0}{ j = $NF;if ( j <= var && j > highest ) { highest=j} } END {print highest}' YourInputFile, Mike
Linux and Unix Tips, Tricks and Individual Advice - The Linux and Unix Menagerie!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
•
•
Posts: 148
Reputation:
Solved Threads: 26
awk '$NF <=3 {a[NR]=$NF;c[a[NR]]=$0}
END{
n=asort(a,b)
print c[b[n]]
}' file# ./test.sh 18 126 2833 30 0.010479 2.842
•
•
Posts: 399
Reputation:
Solved Threads: 47
I knew there was a better answer out there
GhostDog74, you are an awk master! If you don't mind me posting this here, could you point me to a good awk tutorial on the web. I'd like to better understand a lot of programmatical aspects of it.
Thanks in advance and good stuff
Cheers,
Mike
GhostDog74, you are an awk master! If you don't mind me posting this here, could you point me to a good awk tutorial on the web. I'd like to better understand a lot of programmatical aspects of it.
Thanks in advance and good stuff

Cheers,
Mike
Linux and Unix Tips, Tricks and Individual Advice - The Linux and Unix Menagerie!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
•
•
Posts: 148
Reputation:
Solved Threads: 26
•
•
Posts: 399
Reputation:
Solved Threads: 47
Cool,
Thank you very much
I'll definitely check out these links (already adding them to my favorites).
You're very humble and come up with some excellent answers. I'm sure I'll see more in the future and I look forward to it
Thanks, again!
, Mike
Thank you very much
I'll definitely check out these links (already adding them to my favorites).You're very humble and come up with some excellent answers. I'm sure I'll see more in the future and I look forward to it

Thanks, again!
, Mike
Linux and Unix Tips, Tricks and Individual Advice - The Linux and Unix Menagerie!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
------------------------------------------------------------------------
The greatest viral marketing idea of all time, get your copy of this Free Report now!
![]() |
Other Threads in the Shell Scripting Forum
- Previous Thread: Awk question
- Next Thread: Shell Programming Project
•
•
•
•
Views: 1405 | Replies: 6 | Currently Viewing: 1 (0 members and 1 guests)





Linear Mode