xlsx-generator

When to Use This Skill

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "xlsx-generator" with this command: npx skills add jwynia/agent-skills/jwynia-agent-skills-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

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Automation

frontend-design

No summary provided by upstream source.

Repository SourceNeeds Review
1.5K-jwynia
Automation

web-search-tavily

No summary provided by upstream source.

Repository SourceNeeds Review
603-jwynia
Automation

presentation-design

No summary provided by upstream source.

Repository SourceNeeds Review
555-jwynia
Automation

godot-best-practices

No summary provided by upstream source.

Repository SourceNeeds Review
474-jwynia