xlsx-generator

安装量: 137
排名: #6305

安装

npx skills add https://github.com/jwynia/agent-skills --skill xlsx-generator

XLSX Generator When to Use This Skill

Use this skill when:

Creating Excel spreadsheets programmatically from data or specifications Populating branded templates with dynamic content while preserving formatting Extracting cell data, formulas, and structure from existing XLSX files Finding and replacing placeholder text like {{TITLE}} or ${date} in cells Automating spreadsheet generation workflows (reports, data exports, financial statements)

Do NOT use this skill when:

User wants to open/view spreadsheets (use native Excel or viewer) Complex pivot tables or charts are required (limited support) Working with older .xls format (XLSX only) Real-time collaborative editing is needed Prerequisites Deno installed (https://deno.land/) Input XLSX files for template-based operations JSON specification for scratch generation Quick Start Two Modes of Operation

Template Mode: Modify existing branded templates

Analyze template to find placeholders and structure Replace {{PLACEHOLDERS}} with actual values

Scratch Mode: Create spreadsheets from nothing using JSON specifications

Instructions Mode 1: Template-Based Generation Step 1a: Analyze the Template

Extract cell inventory to understand what can be replaced:

deno run --allow-read scripts/analyze-template.ts financial-template.xlsx > inventory.json

Output (inventory.json):

{ "filename": "financial-template.xlsx", "sheetCount": 3, "sheets": [ { "name": "Summary", "rowCount": 25, "colCount": 8, "usedRange": "A1:H25", "cells": [ { "address": "A1", "row": 1, "col": 1, "value": "{{REPORT_TITLE}}", "type": "string" }, { "address": "B3", "row": 3, "col": 2, "value": "{{DATE}}", "type": "string" }, { "address": "C5", "row": 5, "col": 3, "value": null, "type": "number", "formula": "SUM(C6:C20)" } ] } ], "placeholders": [ { "tag": "{{REPORT_TITLE}}", "location": "Summary!A1", "sheet": "Summary", "address": "A1" }, { "tag": "{{DATE}}", "location": "Summary!B3", "sheet": "Summary", "address": "B3" } ], "hasFormulas": true }

Step 1b: Create Replacement Specification

Create replacements.json:

{ "textReplacements": [ { "tag": "{{REPORT_TITLE}}", "value": "Q4 2024 Financial Report" }, { "tag": "{{DATE}}", "value": "December 15, 2024" }, { "tag": "{{COMPANY}}", "value": "Acme Corporation", "sheets": ["Summary", "Cover"] } ], "cellUpdates": [ { "sheet": "Data", "address": "B5", "value": 1250000 }, { "sheet": "Data", "address": "B6", "value": 750000 } ] }

Step 1c: Generate Output deno run --allow-read --allow-write scripts/generate-from-template.ts \ financial-template.xlsx replacements.json output.xlsx

Mode 2: From-Scratch Generation Step 2a: Create Specification

Create spec.json:

{ "title": "Sales Report", "author": "Finance Team", "sheets": [ { "name": "Sales Data", "data": [ ["Product", "Q1", "Q2", "Q3", "Q4", "Total"], ["Widget A", 10000, 12000, 15000, 18000, null], ["Widget B", 8000, 9000, 11000, 13000, null], ["Widget C", 5000, 6000, 7000, 8000, null] ], "cells": [ { "address": "F2", "formula": "SUM(B2:E2)" }, { "address": "F3", "formula": "SUM(B3:E3)" }, { "address": "F4", "formula": "SUM(B4:E4)" } ], "columns": [ { "col": "A", "width": 15 }, { "col": "B", "width": 10 }, { "col": "C", "width": 10 }, { "col": "D", "width": 10 }, { "col": "E", "width": 10 }, { "col": "F", "width": 12 } ], "freezePane": "A2", "autoFilter": "A1:F4" } ] }

Step 2b: Generate Spreadsheet deno run --allow-read --allow-write scripts/generate-scratch.ts spec.json output.xlsx

Examples Example 1: Monthly Sales Report

Scenario: Generate a monthly sales report from template.

Steps:

1. Analyze template for replaceable content

deno run --allow-read scripts/analyze-template.ts sales-template.xlsx --pretty

2. Create replacements.json with monthly data

3. Generate report

deno run --allow-read --allow-write scripts/generate-from-template.ts \ sales-template.xlsx replacements.json November-Sales.xlsx

Example 2: Data Export with Formulas

Scenario: Create a spreadsheet with calculated totals.

spec.json:

{ "sheets": [{ "name": "Expenses", "data": [ ["Category", "January", "February", "March", "Total"], ["Office", 1500, 1600, 1400, null], ["Travel", 3000, 2500, 4000, null], ["Software", 500, 500, 500, null], ["Total", null, null, null, null] ], "cells": [ { "address": "E2", "formula": "SUM(B2:D2)" }, { "address": "E3", "formula": "SUM(B3:D3)" }, { "address": "E4", "formula": "SUM(B4:D4)" }, { "address": "B5", "formula": "SUM(B2:B4)" }, { "address": "C5", "formula": "SUM(C2:C4)" }, { "address": "D5", "formula": "SUM(D2:D4)" }, { "address": "E5", "formula": "SUM(E2:E4)" } ] }] }

Example 3: Multi-Sheet Workbook

Scenario: Create a workbook with summary and detail sheets.

spec.json:

{ "title": "Q4 Report", "sheets": [ { "name": "Summary", "data": [ ["Department", "Budget", "Actual", "Variance"], ["Sales", 500000, 520000, null], ["Marketing", 200000, 195000, null] ], "cells": [ { "address": "D2", "formula": "C2-B2" }, { "address": "D3", "formula": "C3-B3" } ] }, { "name": "Sales Detail", "data": [ ["Month", "Revenue", "Cost", "Profit"], ["October", 180000, 120000, null], ["November", 170000, 115000, null], ["December", 170000, 110000, null] ], "cells": [ { "address": "D2", "formula": "B2-C2" }, { "address": "D3", "formula": "B3-C3" }, { "address": "D4", "formula": "B4-C4" } ] } ] }

Script Reference Script Purpose Permissions analyze-template.ts Extract cells, formulas, placeholders from XLSX --allow-read generate-from-template.ts Replace placeholders in templates --allow-read --allow-write generate-scratch.ts Create XLSX from JSON specification --allow-read --allow-write Specification Reference Sheet Options Property Type Description name string Sheet name data array 2D array of cell values starting at A1 cells array Individual cell specifications rows array Row-based data specifications columns array Column width and visibility settings merges array Merged cell ranges freezePane string Freeze panes at this cell (e.g., "A2") autoFilter string Auto-filter range (e.g., "A1:F10") Cell Options Property Type Description address string Cell address (e.g., "A1", "B2") value mixed Cell value (string, number, boolean, null) formula string Formula without = sign format string Number format (e.g., "#,##0.00") type string Force type: "string", "number", "boolean", "date" Column Options Property Type Description col string Column letter (e.g., "A", "B", "AA") width number Column width in characters hidden boolean Hide column Template Replacement Options Property Type Description tag string Placeholder to find (e.g., "{{TITLE}}") value mixed Replacement value sheets array Limit to specific sheets range string Limit to cell range (e.g., "A1:D10") Common Issues and Solutions Issue: Placeholders not being replaced

Symptoms: Output XLSX still contains {{PLACEHOLDER}} tags.

Solution:

Run analyze-template.ts to verify exact tag text and location Check that placeholder is in a string cell, not a formula Verify sheet filter in replacement spec Issue: Formulas showing as text

Symptoms: Formulas display as text instead of calculating.

Solution:

Ensure formula doesn't start with "=" in spec (it's added automatically) Check cell type is not forced to "string" Issue: Numbers formatted as text

Symptoms: Numbers have green triangle indicating text storage.

Solution:

Use numeric values in spec, not quoted strings For template replacement, if entire cell is placeholder and replacement is number, it converts automatically Issue: Column widths not applied

Symptoms: Columns have default width despite specification.

Solution:

Ensure column letters are uppercase Verify column spec is in array format Limitations XLSX only: Does not support legacy .xls or .xlsb formats No macros: Cannot create or preserve VBA macros Limited charting: No native chart creation support No pivot tables: Cannot create pivot tables programmatically Basic styling: Limited cell formatting options No conditional formatting: Cannot set conditional format rules Formula recalc: Formulas are stored but not recalculated (Excel recalculates on open) Related Skills pptx-generator: For creating PowerPoint presentations docx-generator: For creating Word documents csv-processor: For simpler CSV data processing

返回排行榜