Date: Fri, 12 May 2006 10:41:34 -0600 (MDT) From: Warren Block <wblock@wonkity.com> To: Giorgos Keramidas <keramida@ceid.upatras.gr> Cc: Martin McCormick <martin@dc.cis.okstate.edu>, freebsd-questions@freebsd.org Subject: Re: Trimming Whitespace From Beginning and end of Text Lines Message-ID: <20060512102134.J14220@wonkity.com> In-Reply-To: <20060512150608.GB25497@gothmog.pc> References: <200605121450.k4CEokhn022089@dc.cis.okstate.edu> <20060512150608.GB25497@gothmog.pc>
next in thread | previous in thread | raw e-mail | index | archive | help
On Fri, 12 May 2006, Giorgos Keramidas wrote: > There are at least the following ways: > > sed -i -e 's/^[[:space:]]*' -e 's/[[:space:]]*$//' file ... > perl -pi -e 's/^\s*(\S.*\S)[ \t]*$/$1/' file ... > > The first one seems more straightforward to me most of the time, > but there are times I find Perl's `-pi -e ...' idiom very convenient. Neither of those work here: The first sed expression is missing "//". Correcting that: sed -i -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//' test.txt sed: lstat: No such file or directory The Perl version shows no difference between the original and processed file. It's complex, too. This one works: perl -pi -le 's/^\s+//; s/\s+$//' test.txt Notes: 1. sed always seems to be a pain. My compliments to those who use it regularly; the only time I use it at all is when Perl (or something else with better handling of regular expressions) is not available. 2. The -l option to perl is needed to preserve line endings. 3. The last version is based on the more efficient way of doing it as per: man -P 'less +/trim' perlop -Warren Block * Rapid City, South Dakota USA
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20060512102134.J14220>