원클릭으로
open-xml-xlsx
// Guide and examples for using OpenXML Xlsx features in the open_xml package.
// Guide and examples for using OpenXML Xlsx features in the open_xml package.
Guide and examples for using OpenXML Docx features in the open_xml package.
Guide and examples for using OpenXML Package features in the open_xml package.
Guide and examples for using OpenXML Pptx features in the open_xml package.
| name | open-xml-xlsx |
| description | Guide and examples for using OpenXML Xlsx features in the open_xml package. |
The open_xml package provides robust support for generating, editing, and parsing Excel Workbooks.
To create a new Workbook and add a Sheet:
import 'package:open_xml/open_xml.dart';
import 'package:file/local.dart';
Future<void> main() async {
const fs = LocalFileSystem();
final workbook = await Workbook.create(fs);
// Add a new worksheet
final sheet = workbook.addSheet('Sales Report');
await workbook.save(fs.file('sales.xlsx'));
}
You can add rows to a sheet and insert cells of various types.
// Header Row
sheet.addRow()
..addCell('Product')
..addCell('Price')
..addCell('Quantity')
..addCell('Total');
// Data Row (String, Double, Int)
sheet.addRow()
..addCell('Apples')
..addCell(1.20)
..addCell(50)
..addCell('', formula: 'B2*C2');
The formula parameter on addCell computes values dynamically within Excel.
The package provides utility patterns commonly found in examples/xlsx/ to convert standard data shapes to Excel sheets.
If you have a JSON list:
final List<Map<String, dynamic>> jsonData = [
{"id": 1, "name": "Alice"},
{"id": 2, "name": "Bob"}
];
final sheet = workbook.addSheet('Users');
// Add Header
sheet.addRow()
..addCell('ID')
..addCell('Name');
// Add Rows
for (final row in jsonData) {
sheet.addRow()
..addCell(row['id'])
..addCell(row['name']);
}
Similar looping mechanisms can be used to convert CSV arrays or SQLite streams directly into Excel cells dynamically.
You can add internal links (linking to other cells or sheets within the same workbook) and external hyperlinks.
// Internal Link to Cell A1 on another sheet
sheet.addRow().addCell(
'Go to Sheet 2',
hyperlink: '#\'Sheet 2\'!A1'
);
// External Web Hyperlink
sheet.addRow().addCell(
'Visit Website',
hyperlink: 'https://example.com'
);
You can open existing Excel workbooks and read row data.
final workbook = await Workbook.open(fs.file('data.xlsx'));
for (final sheet in workbook.sheets) {
for (final row in sheet.rows) {
for (final cell in row.cells) {
print(cell.value);
}
}
}