file-converter
Original:🇺🇸 English
Translated
This skill handles file format conversions across documents (PDF, DOCX, Markdown, HTML, TXT), data files (JSON, CSV, YAML, XML, TOML), and images (PNG, JPG, WebP, SVG, GIF). Use when the user requests converting, transforming, or exporting files between formats. Generates conversion code dynamically based on the specific request.
5installs
Source89jobrien/steve
Added on
NPX Install
npx skill4agent add 89jobrien/steve file-converterTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →File Converter
Overview
Convert files between formats across three categories: documents, data files, and images. Generate Python code dynamically for each conversion request, selecting appropriate libraries and handling edge cases.
Conversion Categories
Documents
| From | To | Recommended Library |
|---|---|---|
| Markdown | HTML | |
| HTML | Markdown | |
| HTML | | |
| Text | | |
| DOCX | Markdown | |
| DOCX | | |
| Markdown | Convert via HTML first, then to PDF |
Data Files
| From | To | Recommended Library |
|---|---|---|
| JSON | YAML | |
| YAML | JSON | |
| JSON | CSV | |
| CSV | JSON | |
| JSON | TOML | |
| XML | JSON | |
| JSON | XML | |
Images
| From | To | Recommended Library |
|---|---|---|
| PNG/JPG/WebP/GIF | Any raster | |
| SVG | PNG/JPG | |
| PNG | SVG | |
Workflow
- Identify source format (from file extension or user statement)
- Identify target format
- Check for format-specific guidance
references/ - Generate conversion code using recommended library
- Handle edge cases (encoding, transparency, nested structures)
- Execute conversion and report results
Quick Patterns
Data: JSON to YAML
python
import json
import yaml
with open("input.json") as f:
data = json.load(f)
with open("output.yaml", "w") as f:
yaml.dump(data, f, default_flow_style=False, allow_unicode=True)Data: CSV to JSON
python
import csv
import json
with open("input.csv") as f:
reader = csv.DictReader(f)
data = list(reader)
with open("output.json", "w") as f:
json.dump(data, f, indent=2)Document: Markdown to HTML
python
import markdown
with open("input.md") as f:
md_content = f.read()
html = markdown.markdown(md_content, extensions=["tables", "fenced_code"])
with open("output.html", "w") as f:
f.write(html)Image: PNG to WebP
python
from PIL import Image
img = Image.open("input.png")
img.save("output.webp", "WEBP", quality=85)Image: SVG to PNG
python
import cairosvg
cairosvg.svg2png(url="input.svg", write_to="output.png", scale=2)Resources
Detailed guidance for complex conversions is in :
references/- - PDF handling, encoding issues, styling preservation
references/document-conversions.md - - Schema handling, type coercion, nested structures
references/data-conversions.md - - Quality settings, transparency, color profiles
references/image-conversions.md
Consult these references when handling edge cases or when the user has specific quality/fidelity requirements.