sd - s[earch] & d[isplace]
sd
is an intuitive find & replace CLI.
The Pitch
Why use it over any existing tools?
Painless regular expressions
sd
uses regex syntax that you already know from JavaScript and Python. Forget about dealing with quirks of sed
or awk
- get productive immediately.
String-literal mode
Non-regex find & replace. No more backslashes or remembering which characters are special and need to be escaped.
Easy to read, easy to write
Find & replace expressions are split up, which makes them easy to read and write. No more messing with unclosed and escaped slashes.
Comparison to sed
While sed does a whole lot more, sd
focuses on doing just one thing and doing it well.
Some cherry-picked examples, where sd
shines:
- Simpler syntax for replacing all occurrences:
- sd:
sd before after
- sed:
sed s/before/after/g
- sd:
- Replace newlines with commas:
- sd:
sd '\r' ','
- sed:
sed ':a;N;$!ba;s/\r/,/g'
, or use a different tool liketr
.
- sd:
- Familiar regex syntax by default:
- sd:
echo "start middle end" | sd 'start (.+) end' '$1'
- sed: basic REs have an unfamiliar and limited syntax,
-E
for more familiar syntax of extended regular expressions is widely supported but not available on some platforms like Solaris:echo "start middle end" | sed 's/start \(..*\) end/\1/g'
echo "start middle end" | sed -E 's/start (.+) end/\1/g'
- sd:
- Extracting stuff out of strings containing slashes:
- sd:
echo "sample with /path/" | sd '.*(/.*/)' '$1'
- sed: you need to know that the delimiters for
s
can be replaced with other arbitrary charactersecho "sample with /path/" | sed -E 's|.*(/.*/)|\1|g'
- sd:
- In place modification of files:
- sd:
sd before after -i file.txt
- sed: you need to be careful to use
-e
or else some platforms will consider the next argument to be a backup suffixsed -i -e 's/before/after/g' file.txt
- sd:
Installation
Cargo
OS Packages
- Arch linux: There's an AUR package for sd.
Quick Guide
- String-literal mode. By default, expressions are treated as regex. Use
-s
or--string-mode
to disable regex.
> echo |
- Basic regex use - let's trim some trailing whitespace
> echo |
- Capture groups
Indexed capture groups:
> echo |
Named capture groups:
> echo |
In the unlikely case you stumble upon ambiguities, resolve them by using ${var}
instead of $var
. Here's an example:
> echo |
> echo |
- Find & replace in a file
> sd
That's it. The file is modified in-place.
To do a dry run, just use stdin/stdout:
> sd
- Find & replace across project
Good ol' unix philosophy to the rescue.
Same, but with backups (consider version control).
for; do
;
done