From a6127b6f467326754375f1de64b14a65d403b0fd Mon Sep 17 00:00:00 2001 From: Aditya Kresna Date: Mon, 12 Dec 2022 11:08:50 +0700 Subject: [PATCH 1/3] update example --- README.md | 63 ++++++++++++++++++++++++++++++++++--------------------- 1 file changed, 39 insertions(+), 24 deletions(-) diff --git a/README.md b/README.md index 5d1b602..25a2927 100644 --- a/README.md +++ b/README.md @@ -9,30 +9,45 @@ ### Example ``` -const fs = require('fs'); +// index.js +const path = require('path'); const { CsvFileWriter, Converter } = require("fastexcel"); -// Part 1: Put Data to CSV/Text -const writer = new CsvFileWriter("./test/source-lib.csv", [ - "No", - "Name", - "Gender", -]); - -const rows = [ - [1, "John", "Male"], - [2, "Doe", "Male"], -]; - -for (const row of rows) { - await writer.write(row); -} - -await writer.close(); - -// Part 2: Convert csv to excel -const res = await Converter.toXLSX( - "./test/source-lib.csv", - "./test/result-lib.xlsx", -); +const main = async () => { + const src = path.join(process.cwd(), 'example/source.csv'); + const dst = path.join(process.cwd(), 'example/generated.xlsx'); + + console.log('src', src); + console.log('dst', dst); + + const cols = []; + const totalCols = 200; + for (let i = 0; i < totalCols; i++) { + cols.push('Col ' + (i+1)); + } + + const writer = new CsvFileWriter(src, cols); + + const totalRows = 1000000; // 1jt rows + for (let i = 0; i < totalRows; i++) { + let row = []; + + for (let i = 0; i < totalCols; i++) { + row.push('Col No ' + (i+1)); + } + + row.push(row); + await writer.write(row); + } + + await writer.close(); + + // Part 2: Convert csv to excel + const res = await Converter.toXLSX( + src, + dst + ); +}; + +main(); ``` From 49a804e3dff5bf6e8b21f1b0930af44f575dc77a Mon Sep 17 00:00:00 2001 From: Aditya Kresna Date: Mon, 12 Dec 2022 11:36:55 +0700 Subject: [PATCH 2/3] update readme --- README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/README.md b/README.md index 25a2927..a75ccc8 100644 --- a/README.md +++ b/README.md @@ -2,10 +2,14 @@ > This project using [Neon](https://neon-bindings.com) as a binding to Rust to execute fast and efficient memory usage for generating XLSX document. +> Check here for [Rust installation instruction](https://www.rust-lang.org/tools/install) + ### Installation npm i fastexcel + npm i -D cargo-cp-artifact + ### Example ``` From 7adec8328d6245c7fc9d9f3f77cf24c8ca9ef4b4 Mon Sep 17 00:00:00 2001 From: Aditya Kresna Date: Mon, 12 Dec 2022 11:37:43 +0700 Subject: [PATCH 3/3] bump v0.1.3 --- package-lock.json | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/package-lock.json b/package-lock.json index 4397665..7161614 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "fastexcel", - "version": "0.1.2", + "version": "0.1.3", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "fastexcel", - "version": "0.1.2", + "version": "0.1.3", "hasInstallScript": true, "license": "MIT", "devDependencies": { diff --git a/package.json b/package.json index 59539fe..891a478 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "fastexcel", - "version": "0.1.2", + "version": "0.1.3", "description": "Fast and efficient large excel file writer", "main": "dist/index.js", "scripts": {