Size: 1195
Comment: clean up
|
Size: 1130
Comment: igli: *sigh* BASH handles strings fine. m00 gc ;-)
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
[[Anchor(faq67)]] | <<Anchor(faq67)>> |
Line 3: | Line 3: |
There are a few ways to do this -- none of them elegant. First, the most portable way would be to use `sed`: |
There are a few ways to do this: |
Line 8: | Line 6: |
# POSIX x=$(echo "$x" | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//') |
#POSIX, but fails if the variable contains newlines read -r var << EOF $var EOF |
Line 12: | Line 12: |
One can also achieve the same goal using Bash builtins: | The easiest and cleanest way is with a bash herestring: {{{ 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. |
Line 14: | Line 18: |
{{{ # Bash # Remove leading whitespace: while [[ $x = [[:space:]]* ]]; do x=${x#[[:space:]]}; done # And now trailing: while [[ $x = *[[:space:]] ]]; do x=${x%[[:space:]]}; done }}} Of course, the preceding example is not optimal, because it removes one character at a time, in a loop (although it's good enough in practice for most purposes). If you want something a bit fancier, there's a solution using [:glob:extglob]: |
There's also a solution using [[glob|extglob]] which shows how you can use it in parameter expansion: |
Line 39: | Line 33: |
There are many, many other ways to do this. These are not necessarily the best, but they're known to work. | There are many, many other ways to do this, using sed for instance: {{{ # POSIX, suppress the trailing and leading whitespace on every lines x=$(echo "$x" | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//') }}} |
How can I trim leading/trailing white space from one of my variables?
There are a few ways to do this:
#POSIX, but fails if the variable contains newlines read -r var << EOF $var EOF
The easiest and cleanest way is with a bash herestring:
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.
There's also a solution using extglob which shows how you can use it in parameter expansion:
# Bash shopt -s extglob x=${x##+([[:space:]])} x=${x%%+([[:space:]])} shopt -u extglob
This also works in KornShell, without needing the explicit extglob setting:
# ksh x=${x##+([[:space:]])} x=${x%%+([[:space:]])}
There are many, many other ways to do this, using sed for instance:
# POSIX, suppress the trailing and leading whitespace on every lines x=$(echo "$x" | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//')