apache-poi

Apache POI - Quick Reference

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 "apache-poi" with this command: npx skills add claude-dev-suite/claude-dev-suite/claude-dev-suite-claude-dev-suite-apache-poi

Apache POI - Quick Reference

When NOT to Use This Skill

  • CSV files - Use OpenCSV, Apache Commons CSV, or Files.lines() for CSV

  • PDF generation - Use Apache PDFBox or iText instead

  • Large Excel files (> 100k rows) - Use SXSSFWorkbook or consider CSV export

  • Excel formulas/macros - POI has limited macro support; consider VBA alternatives

  • Real-time Excel editing - POI is for generation/parsing, not collaborative editing

Deep Knowledge: Use mcp__documentation__fetch_docs with technology: apache-poi for comprehensive API documentation, advanced formatting, and formula handling.

Pattern Essenziali

Maven

<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>5.2.5</version> </dependency>

Create Excel

try (Workbook workbook = new XSSFWorkbook()) { Sheet sheet = workbook.createSheet("Data");

// Header
Row header = sheet.createRow(0);
header.createCell(0).setCellValue("Name");
header.createCell(1).setCellValue("Email");

// Data
Row row = sheet.createRow(1);
row.createCell(0).setCellValue("John");
row.createCell(1).setCellValue("john@email.com");

// Auto-size
sheet.autoSizeColumn(0);
sheet.autoSizeColumn(1);

// Write
workbook.write(new FileOutputStream("output.xlsx"));

}

Export Service

@Service public class ExportService { public byte[] exportToExcel(List<User> users) throws IOException { try (Workbook wb = new XSSFWorkbook(); ByteArrayOutputStream out = new ByteArrayOutputStream()) { Sheet sheet = wb.createSheet("Users"); // ... populate rows wb.write(out); return out.toByteArray(); } } }

REST Download Endpoint

@GetMapping("/export") public ResponseEntity<byte[]> export() throws IOException { byte[] data = exportService.exportToExcel(users); return ResponseEntity.ok() .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=data.xlsx") .contentType(MediaType.APPLICATION_OCTET_STREAM) .body(data); }

Cell Styles

CellStyle headerStyle = workbook.createCellStyle(); Font font = workbook.createFont(); font.setBold(true); headerStyle.setFont(font); cell.setCellStyle(headerStyle);

Anti-Patterns

Anti-Pattern Why It's Wrong Correct Approach

Not closing workbook Memory leak, file locks Use try-with-resources: try (Workbook wb = new XSSFWorkbook())

Creating styles in loops Workbook has max 64,000 styles limit Create styles once, reuse across cells

Using XSSFWorkbook for large files OutOfMemoryError for > 100k rows Use SXSSFWorkbook for streaming writes

Reading entire file into memory Memory exhaustion on large files Use event-based parsing (SAX) for reading

Not setting cell types Data interpreted incorrectly Explicitly set cell type: cell.setCellType(CellType.NUMERIC)

Using autoSizeColumn() for every column Very slow, especially with many rows Manually set widths or use sparingly

Hardcoding column indices Brittle, breaks on column changes Use constants or column name maps

Generating Excel for large datasets Excel has 1M row limit, slow Consider CSV or database export instead

Quick Troubleshooting

Issue Diagnosis Solution

OutOfMemoryError on large Excel Using XSSFWorkbook , all data in memory Switch to SXSSFWorkbook for streaming

IllegalStateException: Cannot get a STRING value from a NUMERIC cell

Wrong cell type getter Check type with cell.getCellType() before reading

File corrupted after generation Workbook not closed properly Use try-with-resources or explicitly call wb.close()

Styles not applying Exceeding 64,000 style limit Reuse CellStyle objects, don't create in loops

Numbers displayed as text in Excel Cell type not set Use cell.setCellType(CellType.NUMERIC) and set value as number

Formula not calculating Formula mode not set Use cell.setCellFormula("SUM(A1:A10)") or force recalc

Very slow generation autoSizeColumn() on large sheets Remove or call only on critical columns

Date formatting incorrect Default format not desired Create date CellStyle with custom format

Related Skills

  • Spring Boot

  • Java

References

  • Apache POI Official Docs

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.

Coding

cron-scheduling

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

token-optimization

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

webrtc

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

react-19

No summary provided by upstream source.

Repository SourceNeeds Review