סקיל docx: יצירה ועריכת מסמכי Word מקצועיים בקלוד קוד
docx הוא הסקיל הרשמי של Anthropic לעבודה עם קבצי Word בקלוד קוד. הסקיל מכסה את כל מסלולי העבודה: יצירת מסמכים מאפס באמצעות docx-js, פתיחה ועריכה של מסמכים קיימים דרך unpack ו-pack של ה-XML, וטיפול במצב מתקדם של tracked changes ו-comments. עם כ-65 אלף התקנות שבועיות זה אחד הסקילים הפופולריים ביותר. בסקירה זו אבחן את היכולות, את שלושת מסלולי העבודה, ומקרי שימוש אמיתיים מעבודה על מערכות לקוחות.
פקודת התקנה
npx skills add https://github.com/anthropics/skills --skill docx
קובץ הסקיל הוא Markdown פתוח. אפשר להוריד אותו ולהריץ בדיקת קוד לפני התקנה דרך הכפתורים שבראש העמוד.
מה הסקיל כולל?
הסקיל מתעד שלושה מסלולי עבודה מרכזיים על קבצי docx, יחד עם כלים לקריאה, להמרה, ולטיפול במאפיינים מתקדמים של Word כמו tracked changes ו-comments.
קוד הסקיל המלא
---
name: docx
description: "Use this skill whenever the user wants to create, read, edit, or manipulate Word documents (.docx files). Triggers include: any mention of 'Word doc', 'word document', '.docx', or requests to produce professional documents with formatting like tables of contents, headings, page numbers, or letterheads. Also use when extracting or reorganizing content from .docx files, inserting or replacing images in documents, performing find-and-replace in Word files, working with tracked changes or comments, or converting content into a polished Word document. If the user asks for a 'report', 'memo', 'letter', 'template', or similar deliverable as a Word or .docx file, use this skill. Do NOT use for PDFs, spreadsheets, Google Docs, or general coding tasks unrelated to document generation."
license: Proprietary. LICENSE.txt has complete terms
---
# DOCX creation, editing, and analysis
## Overview
A .docx file is a ZIP archive containing XML files.
## Quick Reference
| Task | Approach |
|------|----------|
| Read/analyze content | `pandoc` or unpack for raw XML |
| Create new document | Use `docx-js` - see Creating New Documents below |
| Edit existing document | Unpack → edit XML → repack - see Editing Existing Documents below |
### Converting .doc to .docx
Legacy `.doc` files must be converted before editing:
```bash
python scripts/office/soffice.py --headless --convert-to docx document.doc
```
### Reading Content
```bash
# Text extraction with tracked changes
pandoc --track-changes=all document.docx -o output.md
# Raw XML access
python scripts/office/unpack.py document.docx unpacked/
```
### Converting to Images
```bash
python scripts/office/soffice.py --headless --convert-to pdf document.docx
pdftoppm -jpeg -r 150 document.pdf page
```
### Accepting Tracked Changes
To produce a clean document with all tracked changes accepted (requires LibreOffice):
```bash
python scripts/accept_changes.py input.docx output.docx
```
---
## Creating New Documents
Generate .docx files with JavaScript, then validate. Install: `npm install -g docx`
### Setup
```javascript
const { Document, Packer, Paragraph, TextRun, Table, TableRow, TableCell, ImageRun,
Header, Footer, AlignmentType, PageOrientation, LevelFormat, ExternalHyperlink,
InternalHyperlink, Bookmark, FootnoteReferenceRun, PositionalTab,
PositionalTabAlignment, PositionalTabRelativeTo, PositionalTabLeader,
TabStopType, TabStopPosition, Column, SectionType,
TableOfContents, HeadingLevel, BorderStyle, WidthType, ShadingType,
VerticalAlign, PageNumber, PageBreak } = require('docx');
const doc = new Document({ sections: [{ children: [/* content */] }] });
Packer.toBuffer(doc).then(buffer => fs.writeFileSync("doc.docx", buffer));
```
### Validation
After creating the file, validate it. If validation fails, unpack, fix the XML, and repack.
```bash
python scripts/office/validate.py doc.docx
```
### Page Size
```javascript
// CRITICAL: docx-js defaults to A4, not US Letter
// Always set page size explicitly for consistent results
sections: [{
properties: {
page: {
size: {
width: 12240, // 8.5 inches in DXA
height: 15840 // 11 inches in DXA
},
margin: { top: 1440, right: 1440, bottom: 1440, left: 1440 } // 1 inch margins
}
},
children: [/* content */]
}]
```
**Common page sizes (DXA units, 1440 DXA = 1 inch):**
| Paper | Width | Height | Content Width (1" margins) |
|-------|-------|--------|---------------------------|
| US Letter | 12,240 | 15,840 | 9,360 |
| A4 (default) | 11,906 | 16,838 | 9,026 |
**Landscape orientation:** docx-js swaps width/height internally, so pass portrait dimensions and let it handle the swap:
```javascript
size: {
width: 12240, // Pass SHORT edge as width
height: 15840, // Pass LONG edge as height
orientation: PageOrientation.LANDSCAPE // docx-js swaps them in the XML
},
// Content width = 15840 - left margin - right margin (uses the long edge)
```
### Styles (Override Built-in Headings)
Use Arial as the default font (universally supported). Keep titles black for readability.
```javascript
const doc = new Document({
styles: {
default: { document: { run: { font: "Arial", size: 24 } } }, // 12pt default
paragraphStyles: [
// IMPORTANT: Use exact IDs to override built-in styles
{ id: "Heading1", name: "Heading 1", basedOn: "Normal", next: "Normal", quickFormat: true,
run: { size: 32, bold: true, font: "Arial" },
paragraph: { spacing: { before: 240, after: 240 }, outlineLevel: 0 } }, // outlineLevel required for TOC
{ id: "Heading2", name: "Heading 2", basedOn: "Normal", next: "Normal", quickFormat: true,
run: { size: 28, bold: true, font: "Arial" },
paragraph: { spacing: { before: 180, after: 180 }, outlineLevel: 1 } },
]
},
sections: [{
children: [
new Paragraph({ heading: HeadingLevel.HEADING_1, children: [new TextRun("Title")] }),
]
}]
});
```
### Lists (NEVER use unicode bullets)
```javascript
// ❌ WRONG - never manually insert bullet characters
new Paragraph({ children: [new TextRun("• Item")] }) // BAD
new Paragraph({ children: [new TextRun("u2022 Item")] }) // BAD
// ✅ CORRECT - use numbering config with LevelFormat.BULLET
const doc = new Document({
numbering: {
config: [
{ reference: "bullets",
levels: [{ level: 0, format: LevelFormat.BULLET, text: "•", alignment: AlignmentType.LEFT,
style: { paragraph: { indent: { left: 720, hanging: 360 } } } }] },
{ reference: "numbers",
levels: [{ level: 0, format: LevelFormat.DECIMAL, text: "%1.", alignment: AlignmentType.LEFT,
style: { paragraph: { indent: { left: 720, hanging: 360 } } } }] },
]
},
sections: [{
children: [
new Paragraph({ numbering: { reference: "bullets", level: 0 },
children: [new TextRun("Bullet item")] }),
new Paragraph({ numbering: { reference: "numbers", level: 0 },
children: [new TextRun("Numbered item")] }),
]
}]
});
// ⚠️ Each reference creates INDEPENDENT numbering
// Same reference = continues (1,2,3 then 4,5,6)
// Different reference = restarts (1,2,3 then 1,2,3)
```
### Tables
**CRITICAL: Tables need dual widths** - set both `columnWidths` on the table AND `width` on each cell. Without both, tables render incorrectly on some platforms.
```javascript
// CRITICAL: Always set table width for consistent rendering
// CRITICAL: Use ShadingType.CLEAR (not SOLID) to prevent black backgrounds
const border = { style: BorderStyle.SINGLE, size: 1, color: "CCCCCC" };
const borders = { top: border, bottom: border, left: border, right: border };
new Table({
width: { size: 9360, type: WidthType.DXA }, // Always use DXA (percentages break in Google Docs)
columnWidths: [4680, 4680], // Must sum to table width (DXA: 1440 = 1 inch)
rows: [
new TableRow({
children: [
new TableCell({
borders,
width: { size: 4680, type: WidthType.DXA }, // Also set on each cell
shading: { fill: "D5E8F0", type: ShadingType.CLEAR }, // CLEAR not SOLID
margins: { top: 80, bottom: 80, left: 120, right: 120 }, // Cell padding (internal, not added to width)
children: [new Paragraph({ children: [new TextRun("Cell")] })]
})
]
})
]
})
```
**Table width calculation:**
Always use `WidthType.DXA` — `WidthType.PERCENTAGE` breaks in Google Docs.
```javascript
// Table width = sum of columnWidths = content width
// US Letter with 1" margins: 12240 - 2880 = 9360 DXA
width: { size: 9360, type: WidthType.DXA },
columnWidths: [7000, 2360] // Must sum to table width
```
**Width rules:**
- **Always use `WidthType.DXA`** — never `WidthType.PERCENTAGE` (incompatible with Google Docs)
- Table width must equal the sum of `columnWidths`
- Cell `width` must match corresponding `columnWidth`
- Cell `margins` are internal padding - they reduce content area, not add to cell width
- For full-width tables: use content width (page width minus left and right margins)
### Images
```javascript
// CRITICAL: type parameter is REQUIRED
new Paragraph({
children: [new ImageRun({
type: "png", // Required: png, jpg, jpeg, gif, bmp, svg
data: fs.readFileSync("image.png"),
transformation: { width: 200, height: 150 },
altText: { title: "Title", description: "Desc", name: "Name" } // All three required
})]
})
```
### Page Breaks
```javascript
// CRITICAL: PageBreak must be inside a Paragraph
new Paragraph({ children: [new PageBreak()] })
// Or use pageBreakBefore
new Paragraph({ pageBreakBefore: true, children: [new TextRun("New page")] })
```
### Hyperlinks
```javascript
// External link
new Paragraph({
children: [new ExternalHyperlink({
children: [new TextRun({ text: "Click here", style: "Hyperlink" })],
link: "https://example.com",
})]
})
// Internal link (bookmark + reference)
// 1. Create bookmark at destination
new Paragraph({ heading: HeadingLevel.HEADING_1, children: [
new Bookmark({ id: "chapter1", children: [new TextRun("Chapter 1")] }),
]})
// 2. Link to it
new Paragraph({ children: [new InternalHyperlink({
children: [new TextRun({ text: "See Chapter 1", style: "Hyperlink" })],
anchor: "chapter1",
})]})
```
### Footnotes
```javascript
const doc = new Document({
footnotes: {
1: { children: [new Paragraph("Source: Annual Report 2024")] },
2: { children: [new Paragraph("See appendix for methodology")] },
},
sections: [{
children: [new Paragraph({
children: [
new TextRun("Revenue grew 15%"),
new FootnoteReferenceRun(1),
new TextRun(" using adjusted metrics"),
new FootnoteReferenceRun(2),
],
})]
}]
});
```
### Tab Stops
```javascript
// Right-align text on same line (e.g., date opposite a title)
new Paragraph({
children: [
new TextRun("Company Name"),
new TextRun("tJanuary 2025"),
],
tabStops: [{ type: TabStopType.RIGHT, position: TabStopPosition.MAX }],
})
// Dot leader (e.g., TOC-style)
new Paragraph({
children: [
new TextRun("Introduction"),
new TextRun({ children: [
new PositionalTab({
alignment: PositionalTabAlignment.RIGHT,
relativeTo: PositionalTabRelativeTo.MARGIN,
leader: PositionalTabLeader.DOT,
}),
"3",
]}),
],
})
```
### Multi-Column Layouts
```javascript
// Equal-width columns
sections: [{
properties: {
column: {
count: 2, // number of columns
space: 720, // gap between columns in DXA (720 = 0.5 inch)
equalWidth: true,
separate: true, // vertical line between columns
},
},
children: [/* content flows naturally across columns */]
}]
// Custom-width columns (equalWidth must be false)
sections: [{
properties: {
column: {
equalWidth: false,
children: [
new Column({ width: 5400, space: 720 }),
new Column({ width: 3240 }),
],
},
},
children: [/* content */]
}]
```
Force a column break with a new section using `type: SectionType.NEXT_COLUMN`.
### Table of Contents
```javascript
// CRITICAL: Headings must use HeadingLevel ONLY - no custom styles
new TableOfContents("Table of Contents", { hyperlink: true, headingStyleRange: "1-3" })
```
### Headers/Footers
```javascript
sections: [{
properties: {
page: { margin: { top: 1440, right: 1440, bottom: 1440, left: 1440 } } // 1440 = 1 inch
},
headers: {
default: new Header({ children: [new Paragraph({ children: [new TextRun("Header")] })] })
},
footers: {
default: new Footer({ children: [new Paragraph({
children: [new TextRun("Page "), new TextRun({ children: [PageNumber.CURRENT] })]
})] })
},
children: [/* content */]
}]
```
### Critical Rules for docx-js
- **Set page size explicitly** - docx-js defaults to A4; use US Letter (12240 x 15840 DXA) for US documents
- **Landscape: pass portrait dimensions** - docx-js swaps width/height internally; pass short edge as `width`, long edge as `height`, and set `orientation: PageOrientation.LANDSCAPE`
- **Never use `n`** - use separate Paragraph elements
- **Never use unicode bullets** - use `LevelFormat.BULLET` with numbering config
- **PageBreak must be in Paragraph** - standalone creates invalid XML
- **ImageRun requires `type`** - always specify png/jpg/etc
- **Always set table `width` with DXA** - never use `WidthType.PERCENTAGE` (breaks in Google Docs)
- **Tables need dual widths** - `columnWidths` array AND cell `width`, both must match
- **Table width = sum of columnWidths** - for DXA, ensure they add up exactly
- **Always add cell margins** - use `margins: { top: 80, bottom: 80, left: 120, right: 120 }` for readable padding
- **Use `ShadingType.CLEAR`** - never SOLID for table shading
- **Never use tables as dividers/rules** - cells have minimum height and render as empty boxes (including in headers/footers); use `border: { bottom: { style: BorderStyle.SINGLE, size: 6, color: "2E75B6", space: 1 } }` on a Paragraph instead. For two-column footers, use tab stops (see Tab Stops section), not tables
- **TOC requires HeadingLevel only** - no custom styles on heading paragraphs
- **Override built-in styles** - use exact IDs: "Heading1", "Heading2", etc.
- **Include `outlineLevel`** - required for TOC (0 for H1, 1 for H2, etc.)
---
## Editing Existing Documents
**Follow all 3 steps in order.**
### Step 1: Unpack
```bash
python scripts/office/unpack.py document.docx unpacked/
```
Extracts XML, pretty-prints, merges adjacent runs, and converts smart quotes to XML entities (`“` etc.) so they survive editing. Use `--merge-runs false` to skip run merging.
### Step 2: Edit XML
Edit files in `unpacked/word/`. See XML Reference below for patterns.
**Use "Claude" as the author** for tracked changes and comments, unless the user explicitly requests use of a different name.
**Use the Edit tool directly for string replacement. Do not write Python scripts.** Scripts introduce unnecessary complexity. The Edit tool shows exactly what is being replaced.
**CRITICAL: Use smart quotes for new content.** When adding text with apostrophes or quotes, use XML entities to produce smart quotes:
```xml
<!-- Use these entities for professional typography -->
<w:t>Here’s a quote: “Hello”</w:t>
```
| Entity | Character |
|--------|-----------|
| `‘` | ‘ (left single) |
| `’` | ’ (right single / apostrophe) |
| `“` | “ (left double) |
| `”` | ” (right double) |
**Adding comments:** Use `comment.py` to handle boilerplate across multiple XML files (text must be pre-escaped XML):
```bash
python scripts/comment.py unpacked/ 0 "Comment text with & and ’"
python scripts/comment.py unpacked/ 1 "Reply text" --parent 0 # reply to comment 0
python scripts/comment.py unpacked/ 0 "Text" --author "Custom Author" # custom author name
```
Then add markers to document.xml (see Comments in XML Reference).
### Step 3: Pack
```bash
python scripts/office/pack.py unpacked/ output.docx --original document.docx
```
Validates with auto-repair, condenses XML, and creates DOCX. Use `--validate false` to skip.
**Auto-repair will fix:**
- `durableId` >= 0x7FFFFFFF (regenerates valid ID)
- Missing `xml:space="preserve"` on `<w:t>` with whitespace
**Auto-repair won't fix:**
- Malformed XML, invalid element nesting, missing relationships, schema violations
### Common Pitfalls
- **Replace entire `<w:r>` elements**: When adding tracked changes, replace the whole `<w:r>...</w:r>` block with `<w:del>...<w:ins>...` as siblings. Don't inject tracked change tags inside a run.
- **Preserve `<w:rPr>` formatting**: Copy the original run's `<w:rPr>` block into your tracked change runs to maintain bold, font size, etc.
---
## XML Reference
### Schema Compliance
- **Element order in `<w:pPr>`**: `<w:pStyle>`, `<w:numPr>`, `<w:spacing>`, `<w:ind>`, `<w:jc>`, `<w:rPr>` last
- **Whitespace**: Add `xml:space="preserve"` to `<w:t>` with leading/trailing spaces
- **RSIDs**: Must be 8-digit hex (e.g., `00AB1234`)
### Tracked Changes
**Insertion:**
```xml
<w:ins w:id="1" w:author="Claude" w:date="2025-01-01T00:00:00Z">
<w:r><w:t>inserted text</w:t></w:r>
</w:ins>
```
**Deletion:**
```xml
<w:del w:id="2" w:author="Claude" w:date="2025-01-01T00:00:00Z">
<w:r><w:delText>deleted text</w:delText></w:r>
</w:del>
```
**Inside `<w:del>`**: Use `<w:delText>` instead of `<w:t>`, and `<w:delInstrText>` instead of `<w:instrText>`.
**Minimal edits** - only mark what changes:
```xml
<!-- Change "30 days" to "60 days" -->
<w:r><w:t>The term is </w:t></w:r>
<w:del w:id="1" w:author="Claude" w:date="...">
<w:r><w:delText>30</w:delText></w:r>
</w:del>
<w:ins w:id="2" w:author="Claude" w:date="...">
<w:r><w:t>60</w:t></w:r>
</w:ins>
<w:r><w:t> days.</w:t></w:r>
```
**Deleting entire paragraphs/list items** - when removing ALL content from a paragraph, also mark the paragraph mark as deleted so it merges with the next paragraph. Add `<w:del/>` inside `<w:pPr><w:rPr>`:
```xml
<w:p>
<w:pPr>
<w:numPr>...</w:numPr> <!-- list numbering if present -->
<w:rPr>
<w:del w:id="1" w:author="Claude" w:date="2025-01-01T00:00:00Z"/>
</w:rPr>
</w:pPr>
<w:del w:id="2" w:author="Claude" w:date="2025-01-01T00:00:00Z">
<w:r><w:delText>Entire paragraph content being deleted...</w:delText></w:r>
</w:del>
</w:p>
```
Without the `<w:del/>` in `<w:pPr><w:rPr>`, accepting changes leaves an empty paragraph/list item.
**Rejecting another author's insertion** - nest deletion inside their insertion:
```xml
<w:ins w:author="Jane" w:id="5">
<w:del w:author="Claude" w:id="10">
<w:r><w:delText>their inserted text</w:delText></w:r>
</w:del>
</w:ins>
```
**Restoring another author's deletion** - add insertion after (don't modify their deletion):
```xml
<w:del w:author="Jane" w:id="5">
<w:r><w:delText>deleted text</w:delText></w:r>
</w:del>
<w:ins w:author="Claude" w:id="10">
<w:r><w:t>deleted text</w:t></w:r>
</w:ins>
```
### Comments
After running `comment.py` (see Step 2), add markers to document.xml. For replies, use `--parent` flag and nest markers inside the parent's.
**CRITICAL: `<w:commentRangeStart>` and `<w:commentRangeEnd>` are siblings of `<w:r>`, never inside `<w:r>`.**
```xml
<!-- Comment markers are direct children of w:p, never inside w:r -->
<w:commentRangeStart w:id="0"/>
<w:del w:id="1" w:author="Claude" w:date="2025-01-01T00:00:00Z">
<w:r><w:delText>deleted</w:delText></w:r>
</w:del>
<w:r><w:t> more text</w:t></w:r>
<w:commentRangeEnd w:id="0"/>
<w:r><w:rPr><w:rStyle w:val="CommentReference"/></w:rPr><w:commentReference w:id="0"/></w:r>
<!-- Comment 0 with reply 1 nested inside -->
<w:commentRangeStart w:id="0"/>
<w:commentRangeStart w:id="1"/>
<w:r><w:t>text</w:t></w:r>
<w:commentRangeEnd w:id="1"/>
<w:commentRangeEnd w:id="0"/>
<w:r><w:rPr><w:rStyle w:val="CommentReference"/></w:rPr><w:commentReference w:id="0"/></w:r>
<w:r><w:rPr><w:rStyle w:val="CommentReference"/></w:rPr><w:commentReference w:id="1"/></w:r>
```
### Images
1. Add image file to `word/media/`
2. Add relationship to `word/_rels/document.xml.rels`:
```xml
<Relationship Id="rId5" Type=".../image" Target="media/image1.png"/>
```
3. Add content type to `[Content_Types].xml`:
```xml
<Default Extension="png" ContentType="image/png"/>
```
4. Reference in document.xml:
```xml
<w:drawing>
<wp:inline>
<wp:extent cx="914400" cy="914400"/> <!-- EMUs: 914400 = 1 inch -->
<a:graphic>
<a:graphicData uri=".../picture">
<pic:pic>
<pic:blipFill><a:blip r:embed="rId5"/></pic:blipFill>
</pic:pic>
</a:graphicData>
</a:graphic>
</wp:inline>
</w:drawing>
```
---
## Dependencies
- **pandoc**: Text extraction
- **docx**: `npm install -g docx` (new documents)
- **LibreOffice**: PDF conversion (auto-configured for sandboxed environments via `scripts/office/soffice.py`)
- **Poppler**: `pdftoppm` for images
מה זה סקיל docx ולמה הוא חשוב?
docx הוא הסקיל הרשמי של Anthropic לעבודה עם קבצי Word בקלוד קוד. הוא לא מחליף את Microsoft Word, אבל הוא מאפשר לקלוד קוד להפיק ולערוך מסמכים שלמים ברמה מקצועית, בלי לפתוח את התוכנה ובלי הרישוי שלה.
הבעיה שהסקיל פותר נראית פשוטה אבל היא לא: יצירה אוטומטית של מסמכי Word במבנה שמתאים לתבנית החברה. רוב הספריות יודעות לכתוב טקסט, אבל לא יודעות להשתלב נכון עם תבנית קיימת, ובוודאי לא לטפל בתוכן עניינים, ב-tracked changes ובהערות צד. docx של Anthropic ארוז עם הידע על שלושת המסלולים האלה ועם הדפוסים שעובדים בפועל.
שלושת מסלולי העבודה הם: יצירה מאפס באמצעות docx-js (לדוחות חדשים), עריכת מסמך קיים דרך unpack ו-pack של ה-XML הפנימי (לתבניות חברה), וטיפול ב-tracked changes ו-comments (לסבבי משוב). כל מסלול מתועד עם דוגמאות, וקלוד קוד יודע לבחור את המסלול המתאים אוטומטית.
הסקיל הזה משתלב מעולה עם אוטומציות עסקיות שמייצרות מסמכים חוזרים, ועם מערכות פנימיות שצריכות לייצא חוזים, הצעות מחיר ודוחות. במקום שכל מסמך ייכתב ידנית, יש מערכת אוטומטית שמייצרת אותו תוך שניות עם פרטי הלקוח הנכונים.
מה סקיל docx נותן לקלוד קוד?
הסקיל מוסיף לקלוד קוד שכבת ידע מלאה על מבנה קבצי docx, על השימוש ב-docx-js, ועל הטיפול במאפיינים מתקדמים של Word. כל אחת מהיכולות הבאות זמינה אוטומטית עם התקנת הסקיל.
יצירה מאפס עם docx-js
ספריית JavaScript מקיפה להפקת קבצי Word ללא צורך בתוכנת Word עצמה. הסקיל מתעד את כל הדפוסים הנפוצים, החל מפסקה פשוטה ועד דוח של מאות עמודים עם תוכן עניינים אוטומטי, כותרות, וטבלאות מסודרות.
עריכת מסמכים קיימים
מסלול ה-unpack ו-pack מאפשר לפתוח קובץ docx קיים, לערוך את ה-XML הפנימי בצורה מבוקרת, ולהרכיב אותו מחדש. כך משמרים את הסטיילים והמבנה של תבנית החברה תוך החלפת התוכן.
תמיכה ב-Tracked Changes
הסקיל יודע לקרוא תיקוני עריכה והערות בקובץ Word, להציג אותם, לקבל או לדחות אותם באופן פרוגרמטי. שימושי במיוחד למשרדי עורכי דין שעובדים עם חוזים בעריכת צד שני, ולצוותי תוכן שמנהלים סבבי משוב מובנים.
תמונות, לוגו וחתימות
הסקיל יודע להטמיע תמונות מקבצים מקומיים או מ-URL בתוך מסמך Word, עם בקרת גודל ומיקום. שימושי להוספת לוגו של החברה, חתימה דיגיטלית, או צילומי מסך אוטומטיים בדוחות תקופתיים.
בלי הסקיל, קלוד יצטרך לנחש איך משתמשים ב-docx-js ויפיק מסמכים בעלי איכות לא עקבית. עם הסקיל, כל מסמך שיוצא מקלוד קוד עומד בתקן ויזואלי וטכני אחיד.
למי הסקיל הזה מתאים?
משרדי עורכי דין וחשבון: הפקת חוזים, הצעות מחיר, דוחות וחוות דעת בכמויות. הסקיל מאפשר לבנות תבניות פנימיות שמתמלאות אוטומטית מנתוני CRM, ולהוציא מסמכים מוכנים לחתימה תוך שניות. בשילוב עם סקיל pdf אפשר גם לייצא את הפלט ל-PDF להפצה.
חברות ייעוץ ויזמות שמפיקות דוחות מקצועיים: דוחות אסטרטגיים ללקוחות שמשלבים נתונים, גרפים וטקסט אנליטי. הסקיל יחד עם סקיל xlsx להפקת הנתונים הפיננסיים מאפשר לבנות מערכת עבודה מלאה. דוח של 30 עמודים נוצר במקום במספר ימים.
צוותי תוכן וכותבים מקצועיים: יצירה אוטומטית של מסמכי Word ארוכים מתוכן שכתבתם בכלי אחר. הסקיל מטפל בכותרות, תוכן עניינים אוטומטי, מספור עמודים, ועיצוב אחיד לאורך כל המסמך. פלאגין Superpowers שבחנתי בעבר מאפשר לטעון את הסקיל יחד עם סקילים נוספים בסביבת עבודה אחת.
אנשי מכירות שמפיקים הצעות מחיר מותאמות: כל לקוח מקבל הצעת מחיר עם הלוגו של החברה, פירוט המוצרים שלו, ותנאים מותאמים. הסקיל בונה את המסמך תוך שניות במקום שאיש המכירות יערוך אותו ידנית בכל פעם.
מי שלא מתאים: פרויקטים של עיצוב מורכב מאוד, או מסמכים שדורשים מאקרו VBA. עבור עיצוב חזותי מורכב מומלץ ליצור תבנית ידנית ב-Word ואז למלא אותה דרך הסקיל. עבור פעולות שדורשות VBA, הסקיל לא יודע לכתוב את הקוד הזה ועדיף לפנות למפתח VBA מומחה.
איך סקיל docx עזר לי בפרויקטים אמיתיים
חוזה משפטי מותאם לקוח עם תוכן עניינים אוטומטי
משרד עורכי דין צריך להפיק חוזים מותאמים לפי תבנית פנימית. הסקיל יודע למלא משתנים, ליצור תוכן עניינים אוטומטי, ולהוסיף שורות חתימה. המסמך מוכן ב-30 שניות במקום שעה של עבודה ידנית מדויקת.
דוח חודשי מקצועי לחברת ייעוץ אסטרטגי
חברת ייעוץ ביקשה אוטומציה של דוח חודשי שמשלב נתונים מ-Excel ופלטים מ-API. הסקיל בנה מסמך Word עם הדגשות ויזואליות, גרפים מוטמעים מ-Excel, ועמוד שער עם לוגו. הזמן הופך משלוש שעות עבודה למחצית השעה.
תרגום מסמך Word עם שמירה על פורמט
מסמך טכני באנגלית של 80 עמודים עם טבלאות וכותרות מורכבות, היה צריך לתרגם לעברית. הסקיל פתח את הקובץ, חילץ את הטקסט, החליף אותו בתרגום, ושמר על כל העיצוב המקורי. ימי עבודה הפכו לשעה אחת.
ביקורת שינויים על חוזה במצב tracked changes
צד שני בעסקה החזיר חוזה עם 80 שינויים ב-tracked changes. הסקיל סרק את כל השינויים, סיווג אותם לפי סוג (תוספת, מחיקה, שינוי), והפיק דוח שמסכם מהם שינויים מהותיים ומהם קוסמטיים. עורך הדין חסך שעות של מעבר ידני.
ארבעת המקרים האלה מראים שהסקיל מתאים גם לעבודה משפטית מובנית, גם לדוחות יעוץ אסטרטגיים, וגם לפרויקטי תרגום וביקורת. בכל פרויקט, הזמן הנחסך הצדיק את שעות ההטמעה. שילוב הסקיל בתשתית קיימת עם קלוד קוד שמנהל את הזרימה מאפשר לבנות מערכת מסמכים מלאה.
סיכום
docx הוא סקיל חובה לכל מי שעובד עם מסמכי Word באופן קבוע. החיבור בין שלושת מסלולי העבודה, הטיפול ב-tracked changes ובהערות, והתמיכה בעברית מלאה, הופכים אותו לכלי שמשנה את היחס בין זמן העבודה לכמות המסמכים שאפשר להוציא.
אם אתם מתחילים, הריצו את פקודת ההתקנה, בקשו מקלוד לבנות מסמך Word קצר על נושא שאתם מכירים, ופתחו אותו ב-Word. תראו מיד את האיכות. אפשר גם להוריד את קובץ הסקיל המלא ולקרוא אותו לפני התקנה.
בסקירות הבאות אבחן את סקיל webapp-testing לבדיקות אוטומטיות של אפליקציות, ואת סקיל canvas-design ליצירת גרפיקה ויזואלית. לעסקים שמייצרים מסמכי Word באופן שגרתי, זו הזדמנות חיסכון זמן משמעותי.
שיתוף הסקיל
שאלות ותשובות
האם הסקיל פותח את Word עצמו?
לא. הסקיל יוצר ועורך קבצי docx ישירות דרך ספריות תוכנה. אתם יכולים לפתוח את הפלט ב-Word, ב-Pages, ב-Google Docs או ב-LibreOffice. היתרון הוא שהמסמך נוצר בשרת אוטומטי בלי לקנות רישיון Word, ובמהירות גבוהה.
איך הסקיל מטפל בקבצי doc הישנים?
קבצי doc ישנים אינם תואמים ישירות לפעולות של הסקיל. ההמלצה היא להמיר אותם תחילה ל-docx באמצעות LibreOffice בשורת הפקודה. הסקיל כולל פקודה אוטומטית לכך, וההמרה לוקחת מספר שניות לקובץ סטנדרטי.
האם הסקיל תומך בעברית ובכיוון RTL?
כן. ספריית docx-js תומכת בעברית באופן מלא, כולל כיוון מימין לשמאל. הסקיל יודע להגדיר RTL ברמת המסמך ולהבטיח שהטבלאות, הכותרות והרשימות יוצגו נכון. רק בפונטים מומלץ לציין במפורש פונט עברי כמו David או Heebo.
מה ההבדל בין הסקיל הזה לסקיל pdf?
docx מתמחה בקבצי Word עם טקסט שניתן לעריכה, ו-pdf מטפל במסמכים סטטיים. אם אתם רוצים לקחת מסמך Word ולייצא ממנו PDF, התקינו את שני הסקילים יחד. תהליך טבעי הוא לבנות docx, לערוך אותו, ואז לייצא ל-PDF להפצה.
האם אפשר להמיר Word ל-Markdown?
כן. הסקיל משתמש ב-pandoc לחילוץ תוכן Word כ-Markdown נקי, כולל טבלאות, כותרות ורשימות. שימושי במיוחד למפתחים שרוצים להעביר תוכן ממסמך לתיעוד ב-GitHub, או לבונים סטטיים של אתרים שעובדים עם Markdown.
האם הסקיל יודע לטפל בעיצוב מורכב?
כן. הסקיל תומך בהדגשות, צבעי טקסט, גדלי גופן, מרווחי שורה, רווחי פסקה, גבולות תאים וצבעי רקע. עיצובים מאוד מורכבים כמו עיצוב צד-לצד אסימטרי מומלץ לבנות בתבנית קיימת ב-Word ואז למלא אותה דרך הסקיל.
איך עובדים עם תבנית של החברה שיש בה לוגו וכותרת תחתונה?
פתחו את התבנית, ספקו אותה לקלוד יחד עם הסקיל, ובקשו מהסקיל לעבור למסלול ה-edit-template. הוא יעתיק את התבנית, ישמור על הלוגו ועל הכותרת התחתונה, ויחליף רק את התוכן עצמו. תבנית מקצועית מקבלת שימוש חוזר בלי בלאגן.
מה התמיכה ב-comments והערות צד?
הסקיל יכול לקרוא הערות שכבר קיימות בקובץ, להוסיף הערות חדשות, ולמחוק הערות. שימושי במיוחד לסבב משוב פנימי שבו צוות מסמן תיקונים ומבקש שינויים על חוזה או מסמך טכני, בלי לשנות את הטקסט עצמו עד שמאשרים את ההערה.