Differences between revisions 9 and 14 (spanning 5 versions)
Revision 9 as of 2008-07-17 15:56:11
Size: 1107
Editor: wsip-68-15-32-50
Comment:
Revision 14 as of 2009-11-04 15:22:51
Size: 1986
Editor: GreyCat
Comment: add non-loop POSIX trick
Deletions are marked like this. Additions are marked like this.
Line 3: Line 3:
There are a few ways to do this: There are a few ways to do this. Some involve special tricks that only work with whitespace. Others are more general, and can be used to strip leading zeroes, etc.
Line 5: Line 5:
Here's one that only works for whitespace. It relies on the fact that `read` strips all leading and trailing whitespace when `IFS` isn't set:
Line 6: Line 7:
   #POSIX, but fails if the variable contains newlines    # POSIX, but fails if the variable contains newlines
Line 8: Line 9:
   $var 
   EOF 
   $var
   EOF
Line 12: Line 13:
One can also achieve in bash using a herestring Bash can do something similar with a "here string":
Line 14: Line 15:
   # Bash still fails if the variable contains a newline.
   read -r x <<< "$x"
   # Bash
   read -rd '' x <<< "$x"
Line 17: Line 18:
Using an empty string as a delimiter means the read consumes the whole string, as NUL is used. (Remember: BASH only does C-string variables.) This is entirely safe for any text, including newlines.
Line 18: Line 20:
(note: using IFS=$' \t' read -d "" -r x partially fix the "problem" of the newlines but adds a trailing \n)

There's also a solution using [:glob:extglob]:
Here's a solution using [[glob|extglob]] together with [[BashFAQ/073|parameter expansion]]:
Line 28: Line 27:
This solution isn't restricted to whitespace like the first few were. You can remove leading zeroes as well:
{{{
   # Bash
   shopt -s extglob
   x=${x##+(0)}
}}}
Line 30: Line 35:
Line 36: Line 40:
There are many, many other ways to do this, using sed for instance: If you need to remove leading zeroes in a POSIX shell, you can use a loop:
Line 38: Line 42:
   # POSIX, suppress the trailing and leading whitespace on every lines    # POSIX
   while true; do
     case "$var" in
       0*) var=${var#0};;
       *) break;;
     esac
   done
}}}

Or this trick:
{{{
   # POSIX
   zeroes=${var%%[!0]*}
   var=${var#$zeroes}
}}}

There are many, many other ways to do this, using sed for instance:
{{{
   # POSIX, suppress the trailing and leading whitespace on every line
Line 41: Line 63:

These are not necessarily the best, but they're known to work.
Solutions based on external programs like sed are well suited to trimming large files, rather than shell variables.

How can I trim leading/trailing white space from one of my variables?

There are a few ways to do this. Some involve special tricks that only work with whitespace. Others are more general, and can be used to strip leading zeroes, etc.

Here's one that only works for whitespace. It relies on the fact that read strips all leading and trailing whitespace when IFS isn't set:

   # POSIX, but fails if the variable contains newlines
   read -r var << EOF
   $var
   EOF

Bash can do something similar with a "here string":

   # Bash
   read  -rd '' x <<< "$x"

Using an empty string as a delimiter means the read consumes the whole string, as NUL is used. (Remember: BASH only does C-string variables.) This is entirely safe for any text, including newlines.

Here's a solution using extglob together with parameter expansion:

   # Bash
   shopt -s extglob
   x=${x##+([[:space:]])} x=${x%%+([[:space:]])}
   shopt -u extglob

This solution isn't restricted to whitespace like the first few were. You can remove leading zeroes as well:

   # Bash
   shopt -s extglob
   x=${x##+(0)}

This also works in KornShell, without needing the explicit extglob setting:

   # ksh
   x=${x##+([[:space:]])} x=${x%%+([[:space:]])}

If you need to remove leading zeroes in a POSIX shell, you can use a loop:

   # POSIX
   while true; do
     case "$var" in
       0*) var=${var#0};;
       *)  break;;
     esac
   done

Or this trick:

   # POSIX
   zeroes=${var%%[!0]*}
   var=${var#$zeroes}

There are many, many other ways to do this, using sed for instance:

   # POSIX, suppress the trailing and leading whitespace on every line
   x=$(echo "$x" | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//')

Solutions based on external programs like sed are well suited to trimming large files, rather than shell variables.

BashFAQ/067 (last edited 2018-11-29 15:32:42 by GreyCat)