סקיל xlsx: עבודה מקצועית עם קבצי Excel בקלוד קוד
xlsx הוא הסקיל הרשמי של Anthropic לעבודה מסודרת עם קבצי Excel ו-CSV בקלוד קוד. הסקיל מכיל תקני עיצוב לקודי צבע פיננסיים, פורמטים מספריים סטנדרטיים, ומנגנון בדיקה שמבטיח שאף מודל לא יוצא עם שגיאת נוסחה. עם כ-58 אלף התקנות שבועיות זה אחד מסקילי המסמכים הפופולריים, והוא מיועד לאנליסטים, רואי חשבון ומפתחים שמייצרים מודלים פיננסיים. במדריך זה אסקור את היכולות, את התקנים שהסקיל אוכף, ומקרי שימוש אמיתיים מעבודה על מערכות לקוחות.
פקודת התקנה
npx skills add https://github.com/anthropics/skills --skill xlsx
קובץ הסקיל הוא Markdown פתוח. אפשר להוריד אותו ולהריץ בדיקת קוד לפני התקנה דרך הכפתורים שבראש העמוד.
מה הסקיל כולל?
הסקיל מטמיע בקלוד קוד את הסטנדרטים שעובדים פיננסיים מקצועיים מצפים לראות, ביצירת ובעריכת מודלים מסודרים. במקום שכל פרויקט יקבל פלט שונה, הסקיל אוכף תקן אחיד.
קוד הסקיל המלא
---
name: xlsx
description: "Use this skill any time a spreadsheet file is the primary input or output. This means any task where the user wants to: open, read, edit, or fix an existing .xlsx, .xlsm, .csv, or .tsv file (e.g., adding columns, computing formulas, formatting, charting, cleaning messy data); create a new spreadsheet from scratch or from other data sources; or convert between tabular file formats. Trigger especially when the user references a spreadsheet file by name or path — even casually (like "the xlsx in my downloads") — and wants something done to it or produced from it. Also trigger for cleaning or restructuring messy tabular data files (malformed rows, misplaced headers, junk data) into proper spreadsheets. The deliverable must be a spreadsheet file. Do NOT trigger when the primary deliverable is a Word document, HTML report, standalone Python script, database pipeline, or Google Sheets API integration, even if tabular data is involved."
license: Proprietary. LICENSE.txt has complete terms
---
# Requirements for Outputs
## All Excel files
### Professional Font
- Use a consistent, professional font (e.g., Arial, Times New Roman) for all deliverables unless otherwise instructed by the user
### Zero Formula Errors
- Every Excel model MUST be delivered with ZERO formula errors (#REF!, #DIV/0!, #VALUE!, #N/A, #NAME?)
### Preserve Existing Templates (when updating templates)
- Study and EXACTLY match existing format, style, and conventions when modifying files
- Never impose standardized formatting on files with established patterns
- Existing template conventions ALWAYS override these guidelines
## Financial models
### Color Coding Standards
Unless otherwise stated by the user or existing template
#### Industry-Standard Color Conventions
- **Blue text (RGB: 0,0,255)**: Hardcoded inputs, and numbers users will change for scenarios
- **Black text (RGB: 0,0,0)**: ALL formulas and calculations
- **Green text (RGB: 0,128,0)**: Links pulling from other worksheets within same workbook
- **Red text (RGB: 255,0,0)**: External links to other files
- **Yellow background (RGB: 255,255,0)**: Key assumptions needing attention or cells that need to be updated
### Number Formatting Standards
#### Required Format Rules
- **Years**: Format as text strings (e.g., "2024" not "2,024")
- **Currency**: Use $#,##0 format; ALWAYS specify units in headers ("Revenue ($mm)")
- **Zeros**: Use number formatting to make all zeros "-", including percentages (e.g., "$#,##0;($#,##0);-")
- **Percentages**: Default to 0.0% format (one decimal)
- **Multiples**: Format as 0.0x for valuation multiples (EV/EBITDA, P/E)
- **Negative numbers**: Use parentheses (123) not minus -123
### Formula Construction Rules
#### Assumptions Placement
- Place ALL assumptions (growth rates, margins, multiples, etc.) in separate assumption cells
- Use cell references instead of hardcoded values in formulas
- Example: Use =B5*(1+$B$6) instead of =B5*1.05
#### Formula Error Prevention
- Verify all cell references are correct
- Check for off-by-one errors in ranges
- Ensure consistent formulas across all projection periods
- Test with edge cases (zero values, negative numbers)
- Verify no unintended circular references
#### Documentation Requirements for Hardcodes
- Comment or in cells beside (if end of table). Format: "Source: [System/Document], [Date], [Specific Reference], [URL if applicable]"
- Examples:
- "Source: Company 10-K, FY2024, Page 45, Revenue Note, [SEC EDGAR URL]"
- "Source: Company 10-Q, Q2 2025, Exhibit 99.1, [SEC EDGAR URL]"
- "Source: Bloomberg Terminal, 8/15/2025, AAPL US Equity"
- "Source: FactSet, 8/20/2025, Consensus Estimates Screen"
# XLSX creation, editing, and analysis
## Overview
A user may ask you to create, edit, or analyze the contents of an .xlsx file. You have different tools and workflows available for different tasks.
## Important Requirements
**LibreOffice Required for Formula Recalculation**: You can assume LibreOffice is installed for recalculating formula values using the `scripts/recalc.py` script. The script automatically configures LibreOffice on first run, including in sandboxed environments where Unix sockets are restricted (handled by `scripts/office/soffice.py`)
## Reading and analyzing data
### Data analysis with pandas
For data analysis, visualization, and basic operations, use **pandas** which provides powerful data manipulation capabilities:
```python
import pandas as pd
# Read Excel
df = pd.read_excel('file.xlsx') # Default: first sheet
all_sheets = pd.read_excel('file.xlsx', sheet_name=None) # All sheets as dict
# Analyze
df.head() # Preview data
df.info() # Column info
df.describe() # Statistics
# Write Excel
df.to_excel('output.xlsx', index=False)
```
## Excel File Workflows
## CRITICAL: Use Formulas, Not Hardcoded Values
**Always use Excel formulas instead of calculating values in Python and hardcoding them.** This ensures the spreadsheet remains dynamic and updateable.
### ❌ WRONG - Hardcoding Calculated Values
```python
# Bad: Calculating in Python and hardcoding result
total = df['Sales'].sum()
sheet['B10'] = total # Hardcodes 5000
# Bad: Computing growth rate in Python
growth = (df.iloc[-1]['Revenue'] - df.iloc[0]['Revenue']) / df.iloc[0]['Revenue']
sheet['C5'] = growth # Hardcodes 0.15
# Bad: Python calculation for average
avg = sum(values) / len(values)
sheet['D20'] = avg # Hardcodes 42.5
```
### ✅ CORRECT - Using Excel Formulas
```python
# Good: Let Excel calculate the sum
sheet['B10'] = '=SUM(B2:B9)'
# Good: Growth rate as Excel formula
sheet['C5'] = '=(C4-C2)/C2'
# Good: Average using Excel function
sheet['D20'] = '=AVERAGE(D2:D19)'
```
This applies to ALL calculations - totals, percentages, ratios, differences, etc. The spreadsheet should be able to recalculate when source data changes.
## Common Workflow
1. **Choose tool**: pandas for data, openpyxl for formulas/formatting
2. **Create/Load**: Create new workbook or load existing file
3. **Modify**: Add/edit data, formulas, and formatting
4. **Save**: Write to file
5. **Recalculate formulas (MANDATORY IF USING FORMULAS)**: Use the scripts/recalc.py script
```bash
python scripts/recalc.py output.xlsx
```
6. **Verify and fix any errors**:
- The script returns JSON with error details
- If `status` is `errors_found`, check `error_summary` for specific error types and locations
- Fix the identified errors and recalculate again
- Common errors to fix:
- `#REF!`: Invalid cell references
- `#DIV/0!`: Division by zero
- `#VALUE!`: Wrong data type in formula
- `#NAME?`: Unrecognized formula name
### Creating new Excel files
```python
# Using openpyxl for formulas and formatting
from openpyxl import Workbook
from openpyxl.styles import Font, PatternFill, Alignment
wb = Workbook()
sheet = wb.active
# Add data
sheet['A1'] = 'Hello'
sheet['B1'] = 'World'
sheet.append(['Row', 'of', 'data'])
# Add formula
sheet['B2'] = '=SUM(A1:A10)'
# Formatting
sheet['A1'].font = Font(bold=True, color='FF0000')
sheet['A1'].fill = PatternFill('solid', start_color='FFFF00')
sheet['A1'].alignment = Alignment(horizontal='center')
# Column width
sheet.column_dimensions['A'].width = 20
wb.save('output.xlsx')
```
### Editing existing Excel files
```python
# Using openpyxl to preserve formulas and formatting
from openpyxl import load_workbook
# Load existing file
wb = load_workbook('existing.xlsx')
sheet = wb.active # or wb['SheetName'] for specific sheet
# Working with multiple sheets
for sheet_name in wb.sheetnames:
sheet = wb[sheet_name]
print(f"Sheet: {sheet_name}")
# Modify cells
sheet['A1'] = 'New Value'
sheet.insert_rows(2) # Insert row at position 2
sheet.delete_cols(3) # Delete column 3
# Add new sheet
new_sheet = wb.create_sheet('NewSheet')
new_sheet['A1'] = 'Data'
wb.save('modified.xlsx')
```
## Recalculating formulas
Excel files created or modified by openpyxl contain formulas as strings but not calculated values. Use the provided `scripts/recalc.py` script to recalculate formulas:
```bash
python scripts/recalc.py <excel_file> [timeout_seconds]
```
Example:
```bash
python scripts/recalc.py output.xlsx 30
```
The script:
- Automatically sets up LibreOffice macro on first run
- Recalculates all formulas in all sheets
- Scans ALL cells for Excel errors (#REF!, #DIV/0!, etc.)
- Returns JSON with detailed error locations and counts
- Works on both Linux and macOS
## Formula Verification Checklist
Quick checks to ensure formulas work correctly:
### Essential Verification
- [ ] **Test 2-3 sample references**: Verify they pull correct values before building full model
- [ ] **Column mapping**: Confirm Excel columns match (e.g., column 64 = BL, not BK)
- [ ] **Row offset**: Remember Excel rows are 1-indexed (DataFrame row 5 = Excel row 6)
### Common Pitfalls
- [ ] **NaN handling**: Check for null values with `pd.notna()`
- [ ] **Far-right columns**: FY data often in columns 50+
- [ ] **Multiple matches**: Search all occurrences, not just first
- [ ] **Division by zero**: Check denominators before using `/` in formulas (#DIV/0!)
- [ ] **Wrong references**: Verify all cell references point to intended cells (#REF!)
- [ ] **Cross-sheet references**: Use correct format (Sheet1!A1) for linking sheets
### Formula Testing Strategy
- [ ] **Start small**: Test formulas on 2-3 cells before applying broadly
- [ ] **Verify dependencies**: Check all cells referenced in formulas exist
- [ ] **Test edge cases**: Include zero, negative, and very large values
### Interpreting scripts/recalc.py Output
The script returns JSON with error details:
```json
{
"status": "success", // or "errors_found"
"total_errors": 0, // Total error count
"total_formulas": 42, // Number of formulas in file
"error_summary": { // Only present if errors found
"#REF!": {
"count": 2,
"locations": ["Sheet1!B5", "Sheet1!C10"]
}
}
}
```
## Best Practices
### Library Selection
- **pandas**: Best for data analysis, bulk operations, and simple data export
- **openpyxl**: Best for complex formatting, formulas, and Excel-specific features
### Working with openpyxl
- Cell indices are 1-based (row=1, column=1 refers to cell A1)
- Use `data_only=True` to read calculated values: `load_workbook('file.xlsx', data_only=True)`
- **Warning**: If opened with `data_only=True` and saved, formulas are replaced with values and permanently lost
- For large files: Use `read_only=True` for reading or `write_only=True` for writing
- Formulas are preserved but not evaluated - use scripts/recalc.py to update values
### Working with pandas
- Specify data types to avoid inference issues: `pd.read_excel('file.xlsx', dtype={'id': str})`
- For large files, read specific columns: `pd.read_excel('file.xlsx', usecols=['A', 'C', 'E'])`
- Handle dates properly: `pd.read_excel('file.xlsx', parse_dates=['date_column'])`
## Code Style Guidelines
**IMPORTANT**: When generating Python code for Excel operations:
- Write minimal, concise Python code without unnecessary comments
- Avoid verbose variable names and redundant operations
- Avoid unnecessary print statements
**For Excel files themselves**:
- Add comments to cells with complex formulas or important assumptions
- Document data sources for hardcoded values
- Include notes for key calculations and model sections
מה זה סקיל xlsx ולמה הוא חשוב?
xlsx הוא הסקיל הרשמי של Anthropic לעבודה עם קבצי Excel ו-CSV בקלוד קוד. הוא לא מחליף את Excel עצמו, אלא מאפשר לקלוד לייצר ולערוך קבצי xlsx ברמה מקצועית, עם תקני העיצוב שעובדים פיננסיים מצפים לראות.
הבעיה שהסקיל פותר ידועה לכל מי שביקש פעם מ-AI להפיק דוח Excel: התוצאה הראשונה תהיה בדרך כלל קובץ עם הנוסחאות הנכונות, אבל בלי שום תקן עיצוב. צבעים אקראיים, פורמטים מספריים לא אחידים, אין הפרדה בין קלטים להנחיות, ולפעמים גם שגיאת #REF נסתרת בפינה. הסקיל xlsx מאלץ את קלוד לחשוב ולהפיק קובץ שעומד בסטנדרט תעשייתי.
מבנה הסקיל מבוסס על דרישות של בנקי השקעות ושל יועצי אסטרטגיה. הקלטים בכחול, הנוסחאות בשחור, ההפניות בירוק, החיצוניות באדום, ההנחות בנפרד עם תיעוד מקור. אלה לא חוקים שרירותיים אלא תקנים שחוסכים שעות של בלבול לכל מי שיפתח את הקובץ אחר כך.
הסקיל הזה משתלב מעולה עם אוטומציות עסקיות שמייצרות דוחות חוזרים ועם פיתוח מערכות פנימיות שצריכות לייצא Excel ללקוחות. במקום שכל פלט יראה אחרת, יש סטנדרט אחד שעובד.
מה סקיל xlsx נותן לקלוד קוד?
הסקיל מוסיף לקלוד קוד שכבת ידע מלאה על מבני קבצי Excel, על תקני עיצוב פיננסיים, ועל תהליכי בדיקה שמונעים שגיאות נוסחה. כל אחת מהיכולות הבאות אכופה אוטומטית בכל קובץ שייוצא.
מודלים פיננסיים תקניים
הסקיל מטמיע את שיטת קודי הצבע התעשייתית: טקסט כחול לקלטים קשיחים, שחור לנוסחאות, ירוק לקישורים פנימיים בקובץ, אדום לקישורים חיצוניים. כל מי שיפתח את המודל יבין מיד את המבנה.
פורמטים מספריים מובנים
מטבע ב-$#,##0, אחוזים ב-0.0%, מכפילים ב-0.0x. שנים נשמרות כטקסט כדי לא לקבל פסיק (2024 ולא 2,024). מספרים שליליים מוצגים בסוגריים בתקן הפיננסי הנפוץ.
אפס שגיאות נוסחה
הסקיל מריץ סקן על כל הקובץ ומחפש #REF, #DIV/0, #VALUE, #N/A ו-#NAME. אם נמצאת שגיאה הוא לא מסיים. כל הנחה וכל קלט מקבלים תא ייעודי, וכל נוסחה משתמשת בהפניה ולא בערך קשיח.
שמירה על תבניות קיימות
כשמעדכנים קובץ קיים של החברה, הסקיל לומד את הפורמט, את הצבעים ואת הסגנון, ושומר עליהם. הוא לא משחית מבנה שמישהו אחר בנה כדי לכפות את התקנים שלו.
בלי הסקיל, כל בקשה לייצר Excel תניב פלט בסגנון שונה. עם הסקיל, כל הקבצים שעוזבים את קלוד קוד עומדים בתקן אחיד שאפשר להציג ללקוח ישר.
למי הסקיל הזה מתאים?
אנליסטים פיננסיים ויועצי אסטרטגיה: מי שבונה מודלים, דוחות הערכת שווי או מצגות נתונים לעיתים קרובות. הסקיל אוכף את התקנים שהתחום מצפה לראות, וזה מקצר זמן ביקורת איכות פנימי. כל מודל שיוצא מקלוד קוד מוכן לבדיקה.
רואי חשבון והנהלת חשבונות: דוחות חודשיים שחוזרים על עצמם עם נתונים שונים. הסקיל יחד עם סקיל pdf לעיבוד חשבוניות מאפשר לבנות מערכת מקצה לקצה: PDF נכנס, נתונים מחולצים, Excel מסודר יוצא לבדיקה.
צוותי פיתוח שמייצרים דוחות ללקוחות: מערכת SaaS שצריכה לייצא נתונים ב-Excel למשתמשים. הסקיל מבטיח שהפלט נראה מקצועי, וזה מקטין פניות תמיכה על קבצים שלא נראים נכון. הוא משתלב עם קלוד קוד שמנהל את הזרימה.
אנשי תפעול וייעוץ עסקי: בניית מערכת תכנון, מעקב או תקציב עבור החברה. הסקיל מאפשר ליצור גיליונות עבודה תקניים שהחברה תוכל להחזיק לאורך זמן, גם כשעובדים שונים יערכו אותם בעתיד.
מי שלא מתאים: פרויקטים שעוסקים אך ורק במאקרו VBA או בגרפיקה מתקדמת מאוד. הסקיל מתמחה בנוסחאות, פורמטים ומבנה, אבל לא בכתיבת VBA. עבור פרויקטים מורכבים שכאלה, מומלץ לחזור לעבודה ידנית ב-Excel המקומי.
איך סקיל xlsx עזר לי בפרויקטים אמיתיים
מודל DCF להערכת שווי סטארטאפ פינטק
סטארטאפ ביקש מודל DCF של 5 שנים לפני סבב גיוס. הסקיל הוציא קובץ עם הקלטים הצבועים בכחול, הנוסחאות בשחור, וגיליון נפרד של הנחות עם תיעוד מקור לכל מספר. שעה עבודה עם המודל, יום שלם של תיקונים שנחסך.
דוח מכירות חודשי לחנות B2C מנתוני CRM
חנות B2C ביקשה דוח Excel חודשי שמושך נתונים מ-CRM ומציג מכירות לפי קטגוריה. הסקיל בנה תבנית עם גיליון נתונים גולמי, גיליון של pivots וגיליון של גרפים מסכמים. הדוח מתעדכן מאז כל חודש בלחיצת כפתור.
תמחור מותאם של מוצרים לקטגוריות לקוחות
חברת B2B שביקשה מודל תמחור שתומך ב-3 דרגות לקוח עם מטריצת הנחות. הסקיל בנה גיליון עם נוסחאות תנאיות שנבדקו לאפס שגיאות, ועם הסבר תוך-תאי של כל החישוב. הצוות של החברה משתמש במודל מאז ללא תיקונים.
ניקוי קובץ CSV של 50 אלף שורות
לקוח שלח קובץ CSV עם נתוני סקר שהיו בו שורות שבורות, כותרות במקום מוזר, ועמודות עם מטא-דאטה. הסקיל ניקה את הקובץ, אחד את הפורמטים, והוציא Excel נקי לעיבוד הסטטיסטי. עבודה של חצי שעה במקום יום שלם.
ארבעת המקרים האלה מראים שהסקיל מתאים גם לעבודה פיננסית אסטרטגית, גם לדוחות תפעוליים שגרתיים, וגם לעבודת ניקוי נתונים שאף אחד לא רוצה לעשות ידנית. בכל פרויקט הזמן הנחסך הצדיק את שעות ההטמעה של הסקיל פי כמה. בנוסף, פלאגין Superpowers מאפשר לטעון מספר סקילים יחד ולעבוד בצורה אינטגרטיבית.
סיכום
xlsx הוא סקיל חובה לכל מי שמייצר קבצי Excel באופן קבוע. החיבור בין תקני העיצוב הפיננסיים, הפורמטים האחידים ובדיקת אפס השגיאות מעניק פלט שעומד בסטנדרט תעשייתי, בלי שעות של עריכה ידנית.
אם אתם מתחילים, הריצו את פקודת ההתקנה, בקשו מקלוד לבנות מודל פיננסי קצר על נושא שאתם מכירים, ופתחו אותו ב-Excel. תראו מיד את ההבדל מול פלט סטנדרטי של AI. אפשר גם להוריד את קובץ הסקיל המלא ולקרוא אותו לפני התקנה.
בסקירות הבאות אבחן גם את סקיל docx ליצירת מסמכי Word ואת סקיל webapp-testing לבדיקות אוטומטיות. לעסקים שמייצרים דוחות Excel באופן קבוע, זו הזדמנות לחיסכון זמן משמעותי וטווח קצר.
שיתוף הסקיל
שאלות ותשובות
האם צריך לדעת Python כדי להשתמש בסקיל?
לא חובה. קלוד קוד יודע לכתוב את הקוד הנדרש על סמך הסקיל, ואתם רק מתארים את התוצאה הרצויה. אנליסטים פיננסיים בלי רקע פיתוח יכולים לבנות מודלים מורכבים על ידי בקשה בעברית טבעית. הקובץ המוגמר נפתח ב-Excel רגיל וזמין לעריכה ידנית בהמשך.
מה ההבדל בין הסקיל הזה לסקיל pdf?
xlsx מתמחה בקבצי Excel ו-CSV עם נוסחאות חיות, ו-pdf מטפל במסמכי PDF סטטיים. אם אתם רוצים לקחת נתונים מ-PDF ולהפיק מהם דוח Excel מובנה, התקינו את שני הסקילים יחד וקלוד יזרום ביניהם בצורה חלקה.
האם הנוסחאות נכתבות באנגלית או בעברית?
ברירת המחדל היא נוסחאות באנגלית כפי שהסטנדרט בקבצי xlsx. אם אתם משתמשים בגרסת Excel בעברית, הסקיל יוכל לכתוב נוסחאות בעברית כשתבקשו זאת במפורש. ההמלצה היא לעבוד באנגלית כי הקובץ נשאר תאים בכל שפה.
האם הסקיל מטפל בקבצי CSV ו-TSV?
כן. הסקיל יודע לקרוא, לנקות ולמזג קבצי CSV ו-TSV, וגם לייצא אותם מקבצי Excel קיימים. שילוב טבעי הוא לקבל CSV מ-CRM, לעבד אותו ולהפיק דוח Excel מעוצב. הסקיל יודע לטפל בכותרות שגויות, שורות שבורות ועמודות מטא-דאטה.
איך הסקיל מבטיח אפס שגיאות נוסחה?
אחרי כל יצירה ועדכון, הסקיל סורק את כל התאים ובודק אם מופיעות שגיאות #REF, #DIV/0, #VALUE, #N/A או #NAME. אם נמצאות, הוא חוזר ומתקן עד שהקובץ נקי. בנוסף הוא בודק שאין הפניות מעגליות לא מכוונות שגורמות ל-Excel להיתקע.
מה התמיכה בגרפים ובצ'רטים?
הסקיל יודע ליצור גרפי עמודות, קווים, פאי, ופיזור פשוטים, ולשייך אותם לטווחי נתונים. לגרפים מתקדמים יותר כמו waterfall או heatmap, מומלץ לבקש מהסקיל לבנות את הנתונים בגיליון נפרד ולהוסיף את הגרף ידנית ב-Excel.
האם הסקיל עובד עם קבצים מאוד גדולים?
Excel עצמו מוגבל לכמיליון שורות לגיליון, והסקיל מכבד את המגבלה הזאת. עבור קבצי CSV של מעל 100 אלף שורות, הסקיל ממליץ לעבד את הנתונים ב-Python במקום לטעון אותם לזיכרון. במקרים האלה הוא יציע מבנה עיבוד שמרי שירוץ במהירות.
מה לגבי קבצי תבנית עם מאקרו (xlsm)?
הסקיל יכול לקרוא קבצי xlsm ולשמור עליהם, אבל הוא לא יכתוב מאקרו VBA חדש. אם הקובץ שלכם מכיל מאקרו, הסקיל ישמור עליהם בלי לפגוע בהם. לכתיבת מאקרו חדש, מומלץ לעבוד ידנית ב-Excel או לפנות ל-VBA מומחה.