home / skills / 0xdarkmatter / claude-mods / find-replace
This skill helps you perform fast find-and-replace operations using sd across files, with safe batch workflows and preview capabilities.
npx playbooks add skill 0xdarkmatter/claude-mods --skill find-replaceReview the files below or copy the command above to add this skill to your agents.
---
name: find-replace
description: "Modern find-and-replace using sd (simpler than sed) and batch replacement patterns. Triggers on: sd, find replace, batch replace, sed replacement, string replacement, rename."
compatibility: "Requires sd CLI tool. Install: brew install sd (macOS) or cargo install sd (cross-platform)."
allowed-tools: "Bash"
---
# Find Replace
Modern find-and-replace using sd.
## sd Basics
```bash
# Replace in file (in-place)
sd 'oldText' 'newText' file.txt
# Replace in multiple files
sd 'oldText' 'newText' *.js
# Preview without changing (pipe)
cat file.txt | sd 'old' 'new'
```
## sd vs sed
| sed | sd |
|-----|-----|
| `sed 's/old/new/g'` | `sd 'old' 'new'` |
| `sed -i 's/old/new/g'` | `sd 'old' 'new' file` |
| `sed 's#path/to#new/path#g'` | `sd 'path/to' 'new/path'` |
**Key difference:** sd is global by default, no delimiter issues.
## Common Patterns
```bash
# Variable/function rename
sd 'oldName' 'newName' src/**/*.ts
# Word boundaries (avoid partial matches)
sd '\boldName\b' 'newName' src/**/*.ts
# Import path update
sd "from '../utils'" "from '@/utils'" src/**/*.ts
# Capture groups
sd 'console\.log\((.*)\)' 'logger.info($1)' src/**/*.js
```
## Safe Batch Workflow
```bash
# 1. List affected files
rg -l 'oldPattern' src/
# 2. Preview replacements
rg 'oldPattern' -r 'newPattern' src/
# 3. Apply
sd 'oldPattern' 'newPattern' $(rg -l 'oldPattern' src/)
# 4. Verify
rg 'oldPattern' src/ # Should return nothing
git diff # Review changes
```
## Special Characters
| Character | Escape |
|-----------|--------|
| `.` | `\.` |
| `*` | `\*` |
| `[` `]` | `\[` `\]` |
| `$` | `\$` |
| `\` | `\\` |
## Tips
| Tip | Reason |
|-----|--------|
| Always preview with `rg -r` first | Avoid mistakes |
| Use git before bulk changes | Easy rollback |
| Use `\b` for word boundaries | Avoid partial matches |
| Quote patterns | Prevent shell interpretation |
## Additional Resources
For detailed patterns, load:
- `./references/advanced-patterns.md` - Regex, batch workflows, real-world examples
This skill provides a modern find-and-replace workflow using sd for safe, global, and readable text substitution across files. It simplifies common sed patterns, supports regex captures, and integrates a safe batch workflow with ripgrep (rg) for preview and verification. The skill focuses on predictable, in-place edits and easy rollback with git.
The tool runs sd to perform global replacements by default, so patterns do not require delimiters and are less error-prone than sed. It pairs rg for listing and previewing matches, then applies sd to files returned by rg for batched, targeted edits. It supports regex escapes, word boundaries, and capture groups to handle complex renames and import updates.
How is sd different from sed?
sd is global by default, avoids delimiter hassles, and uses simpler syntax for most common replacements. Use sd for clearer, less error-prone global edits.
How do I avoid matching substrings?
Use word boundaries (\b) in your pattern, or include surrounding context in the regex to limit matches.
What if I need to preview changes before modifying files?
Use rg -r 'old' -r 'new' or pipe file content through sd to preview. Also list files with rg -l and inspect them before passing to sd.