spreadsheet_decoder 2.3.0 copy "spreadsheet_decoder: ^2.3.0" to clipboard
spreadsheet_decoder: ^2.3.0 copied to clipboard

A lightweight library for parsing and updating spreadsheet documents

example/spreadsheet_decoder.dart

import 'dart:io';
import 'package:path/path.dart';
import 'package:spreadsheet_decoder/spreadsheet_decoder.dart';

void main(List<String> args) {
  var file = 'test/files/test.xlsx';
  var bytes = File(file).readAsBytesSync();
  var decoder = SpreadsheetDecoder.decodeBytes(bytes, update: true);
  for (var table in decoder.tables.keys) {
    print(table);
    print(decoder.tables[table]!.maxCols);
    print(decoder.tables[table]!.maxRows);
    for (var row in decoder.tables[table]!.rows) {
      print('$row');
    }
  }

  var sheet = decoder.tables.keys.first;
  decoder
    ..updateCell(sheet, 0, 0, "L'oiseau <\"coucou\">")
    ..updateCell(sheet, 1, 0, 'B')
    ..updateCell(sheet, 2, 0, 'C')
    ..updateCell(sheet, 1, 1, 42.3)
    ..insertRow(sheet, 1)
    ..insertRow(sheet, 13)
    ..updateCell(sheet, 0, 13, 'A14')
    ..updateCell(sheet, 0, 12, 'A13')
    ..insertColumn(sheet, 0)
    ..removeRow(sheet, 1)
    ..removeColumn(sheet, 2);

  File(join('test/out/${basename(file)}'))
    ..createSync(recursive: true)
    ..writeAsBytesSync(decoder.encode());

  print('************************************************************');
  for (var table in decoder.tables.keys) {
    print(table);
    print(decoder.tables[table]!.maxCols);
    print(decoder.tables[table]!.maxRows);
    for (var row in decoder.tables[table]!.rows) {
      print('$row');
    }
  }
}
114
likes
150
points
12.8k
downloads

Publisher

unverified uploader

Weekly Downloads

A lightweight library for parsing and updating spreadsheet documents

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

archive, xml

More

Packages that depend on spreadsheet_decoder