Date: Fri, 5 Oct 2001 02:11:56 -0500 From: Mike Meyer <mwm@mired.org> To: Chris Fedde <chris@fedde.littleton.co.us> Cc: questions@freebsd.org, <kory@avatar.com> Subject: Re: Real dumb shell script/awk question Message-ID: <15293.23868.39354.690746@guru.mired.org> In-Reply-To: <32463104@toto.iv>
next in thread | previous in thread | raw e-mail | index | archive | help
Chris Fedde <chris@fedde.littleton.co.us> types: > On Thu, 4 Oct 2001 17:46:53 -0700 "Kory Hamzeh" wrote: > +------------------ > | > | I need to bang together a simple shell script to parse a flat ascii > | database. The fields are variable width, but each field is separated by the > | "|" character. Basically, all this script needs to do is to read the > | database, one line at a line, and if field X is equal to value Y, then print > | the value of field Z. The user must be able to specify X, Y, and Z on the > | command line. > | > | Now, for the life of me, I can't seem to figure out a simple way of doing > | this with a bourne shell script. I think awk can do it, but the man pages > | didn't help me too much with the language. I know other language, like perl, > | are probably better suited, but I need to customize this script per the > | clients request, and it will only be needed for a couple of weeks and he'll > | never need this again. > | > | Any tips on how to do this? I'm sure there is a simple way and I'm drawing a > | blank. > +------------------ > Awk is your friend But metacharacters are your enemy. > $ cat t > asdf|trew|agfd > asdf|asdf|435 > wer|asgf|bwhw > qwert|qewrt|asdf > > $ awk -F'|' -e '$1 == $2 {print $3}' t > 435 That tests field values, not a user-supplied value, and -e isn't an awk option. bash-2.05$ cat test #!/bin/sh # $1 = X, $2 = Y, $3 = Z awk -F'|' "\$$1 == $2 {print \$$3}" bash-2.05$ cat t asdf|trew|agfd asdf|asdf|435 wer|asgf|bwhw qwert|qewrt|asdf bash-2.05$ sh test 3 435 1 < t asdf bash-2.05$ Adding simple argument checking is probably worthwhile, as otherwise awk complains. <mike -- Mike Meyer <mwm@mired.org> http://www.mired.org/home/mwm/ Q: How do you make the gods laugh? A: Tell them your plans. To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-questions" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?15293.23868.39354.690746>