Our review
Converts Markdown files to Word documents (DOCX) with academic formatting, preserving images, tables, and code blocks.
Strengths
- Automated script that preprocesses Markdown before conversion
- Handles relative image paths and resizing
- Post-conversion validation to ensure quality
- Supports metadata and section numbering
Limitations
- Requires Python and pandoc installed (script can download pandoc if missing)
- Advanced formatting (complex tables, annotations) may need manual tweaks
- Does not handle complex diagrams or LaTeX formulas
Use this skill when you need to submit a lab report in DOCX format from a Markdown file.
Avoid this skill if the final document must stay in Markdown, or if you need highly custom layouts beyond pandoc's capabilities.
Security analysis
CautionThe skill involves running a Python script that can download external software (pandoc) and process files. While the intent is legitimate document conversion, the script's behavior (auto-download, file modification) introduces moderate risk if the script is compromised or misused.
- •Skill instructs execution of a Python script from a shared directory (scripts/convert_md_to_docx.py) that may auto-download pandoc (network access).
- •Script modifies document files (removing alt text, horizontal rules) and could potentially overwrite arbitrary files if misused.
Examples
Convert this markdown file to a Word document: Lab_Report.mdConvert my lab answer from markdown to docx using the script and name it Lab_Answer.docxConvert all .md files in this folder to .docx, keeping the same filenamesname: learning-md_to_docx description: Convert markdown lab reports to Word documents with proper formatting. Use when (1) user needs to submit .docx, (2) mentions "转docx" or "convert to word", (3) preparing lab submission.
Learning Markdown to DOCX Converter
Objectives
- Convert .md files to .docx with proper formatting
- Preserve images, tables, and code blocks
- Apply academic document styling
Instructions
1. Recommended: Use the Conversion Script (Best Practice)
Always use the script for lab reports:
python .shared/skills/learning-md_to_docx/scripts/convert_md_to_docx.py Lab_Answer.md
The script automatically:
- Removes image alt text (prevents "Step 1 Code", "Step 1 Result" from appearing in Word)
- Removes horizontal rules
---(prevents visible lines in Word) - Handles relative image paths
- Provides validation checklist
2. Pre-process Markdown (if using pandoc directly)
Remove horizontal rules before conversion:
- Horizontal rules
---in markdown become visible lines in Word - Remove all
---separators if clean layout is desired - Alternative: Use blank lines for section spacing
Remove image alt text manually:
- Change
to - Alt text appears as visible captions below images in Word
3. Direct Pandoc Command (if script unavailable)
Basic command:
pandoc input.md -o output.docx --resource-path="./images"
Alternative: Python script with python-docx
from docx import Document
from docx.shared import Inches, Pt
import markdown
2. Formatting Requirements
Document structure:
- Title: Bold, 16pt
- Student info: Name, ID, Section, Date
- Headings: Hierarchical (Heading 1, 2, 3)
- Body text: 11pt, single spacing
- Code blocks: Courier New, 10pt, gray background
- Images: Centered, with captions
Image handling:
- Convert relative paths to absolute before processing
- Resize images to fit page width (max 6 inches)
- Control captions via alt text:
becomes figure caption - Use empty alt text
to avoid automatic captions - Maintain aspect ratio
3. Conversion Steps
-
Pre-process markdown:
- Remove horizontal rules
---if clean layout is needed - Resolve relative image paths
- Clean up formatting inconsistencies
- Verify all images exist
- Remove horizontal rules
-
Convert to DOCX:
- Use pandoc or python-docx
- Apply formatting rules
- Insert images with proper sizing
-
Post-process DOCX:
- Verify all images display correctly
- Check page breaks
- Ensure consistent formatting
- Add page numbers if required
4. Pandoc Command Examples
Basic conversion:
pandoc Lab1_Template.md -o Lab1.docx
With custom styling:
pandoc Lab1_Template.md -o Lab1.docx \
--reference-doc=academic_template.docx \
--toc \
--number-sections
With metadata:
pandoc Lab1_Template.md -o Lab1.docx \
-M title="Lab 1: Zipf's Law" \
-M author="Student Name" \
-M date="2026-01-20"
A ready-to-use script is available: scripts/convert_md_to_docx.py
Usage:
# Basic conversion
python scripts/convert_md_to_docx.py Lab1_Template.md
# Specify output filename
python scripts/convert_md_to_docx.py Lab1_Template.md Lab1.docx
# The script will:
# - Auto-download pandoc if needed
# - Handle relative image paths
# - Auto-remove image alt text (prevents captions in Word)
# - Provide validation checklist
Features:
- Automatic pandoc installation
- Relative path resolution for images
- Auto-preprocessing:
- Removes image alt text (e.g.,
→) - Removes horizontal rules
---(prevents visible lines in Word) - This prevents alt text from appearing as captions below images in Word
- Removes image alt text (e.g.,
- Error handling and troubleshooting tips
- Validation checklist after conversion
Validation
Check the generated .docx:
- [ ] All images display correctly
- [ ] Headings are properly formatted
- [ ] Code blocks are readable
- [ ] Tables are formatted correctly
- [ ] Page layout is appropriate
- [ ] File size is reasonable (<10MB)
Common Issues
- Missing images: Ensure all image paths are resolved before conversion
- Broken formatting: Use
--reference-docwith proper template - Large file size: Compress images before conversion
- Chinese characters: Ensure UTF-8 encoding:
pandoc -f markdown+east_asian_line_breaks - Unwanted text below images: Image alt text appears as captions in Word. Use empty alt text
![]()or short text![Code]()to avoid verbose captions
Installation
Pandoc:
# Windows (using chocolatey)
choco install pandoc
# Or download from: https://pandoc.org/installing.html
Python packages:
pip install pypandoc python-docx
API Documentation Generator
Documentation
Automatically generates OpenAPI/Swagger API documentation.
Technical Writer
Documentation
Writes clear technical documentation following top style guides.
Pivot Decision Framework
Documentation
Documents a strategic pivot or persevere decision with evidence, analysis, and rationale. Use when evaluating whether to change direction on a product, feature, or strategy based on market feedback.