Bash - an odd problem using sed or awk or for

Patrick O'Callaghan pocallaghan at gmail.com
Fri Nov 30 00:18:09 UTC 2012


On Thu, 2012-11-29 at 23:33 +0000, John Horne wrote:
> Hello,
> 
> I have a bash script in which a variable is set to one or more lines of
> text. What I want is to remove any lines up to and including a blank
> line (or alternatively to echo all the lines after the last blank line).
> There may be zero or more blank lines, and the blank lines need not be
> consecutive. If there is no blank line, then all the lines should be
> shown. If the last line is blank, then nothing should be shown. So for
> example the variable may contain:
> 
> ============ (the '=' are not part of the variable)
> abc def
> 
> hijk
> xyz
> ============
> 
> So in this case what is wanted is:
> 
> ============
> hijk
> xyz
> ============
> 
> to be shown.
> 
> I tried something like:
> 
>    echo "$XX" | sed -e '/./,/^$/d'
> 
> but this didn't display anything. (Where XX is the variable.)
> I also tried using a 'for' loop but again this displayed nothing:
> 
>    opt=""
>    IFS=$'\n'
>    for n in $XX; do test -z "$n" && opt="" || opt="$opt $n"; done
> 
> (Echoing $opt after this shows that it contains nothing.) I'm not sure
> why but even using a for loop just to show it had seen a blank line
> didn't work either (using something like 'test -z "$n" && echo found').
> My understanding was that by setting IFS to a newline, then the 'for'
> loop should see the blank line and just set '$n' to the null string. We
> should then be able to test on that.
> 
> Ideally what I am looking for is a snappy one line 'sed' or 'awk'
> command to handle this :-) Unfortunately at the moment I seem to be
> getting nowhere though, even with the 'for' loop.

echo $FOO | grep .

poc



More information about the users mailing list