- use autolinks (e.g <https://sheetjs.com> -> https://sheetjs.com) - move <summary> blocks to separate lines
		
			
				
	
	
	
		
			7.3 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	| title | pagination_prev | pagination_next | sidebar_position | sidebar_custom_props | ||
|---|---|---|---|---|---|---|
| NodeJS | getting-started/index | getting-started/examples/index | 3 | 
 | 
import current from '/version.js'; import Tabs from '@theme/Tabs'; import TabItem from '@theme/TabItem'; import CodeBlock from '@theme/CodeBlock';
Package tarballs are available on https://cdn.sheetjs.com.
https://cdn.sheetjs.com/xlsx-{current}/xlsx-{current}.tgz is the URL for version {current}
Installation
Tarballs can be directly installed using a package manager:
{`\ npm rm --save xlsx npm i --save https://cdn.sheetjs.com/xlsx-${current}/xlsx-${current}.tgz`} {`\ pnpm rm xlsx pnpm install --save https://cdn.sheetjs.com/xlsx-${current}/xlsx-${current}.tgz`} {`\ yarn remove xlsx yarn add https://cdn.sheetjs.com/xlsx-${current}/xlsx-${current}.tgz`}:::tip pass
Watch the repo or subscribe to the RSS feed to be notified when new versions are released!
:::
:::caution Snyk Bugs
Snyk security tooling may report errors involving "Prototype Pollution":
Prototype Pollution [Medium Severity][https://security.snyk.io/vuln/SNYK-JS-XLSX-5457926]
As noted in the Snyk report:
The issue is resolved in version 0.19.3
Snyk is falsely reporting vulnerabilities. It is a bug in the Snyk tooling.
Until Snyk fixes the bugs, the official recommendation is to suppress the warning.
:::
Legacy Endpoints
:::warning pass
Older releases are technically available on the public npm registry as xlsx,
but the registry is out of date.  The latest version on that registry is 0.18.5
This is a known registry bug
The SheetJS CDN https://cdn.sheetjs.com/ is the authoritative source for SheetJS modules.
For existing projects, the easiest approach is to uninstall and reinstall:
{`\ npm rm --save xlsx npm i --save https://cdn.sheetjs.com/xlsx-${current}/xlsx-${current}.tgz`} {`\ pnpm rm xlsx pnpm install --save https://cdn.sheetjs.com/xlsx-${current}/xlsx-${current}.tgz`} {`\ yarn remove xlsx yarn add https://cdn.sheetjs.com/xlsx-${current}/xlsx-${current}.tgz`}When the xlsx library is a dependency of a dependency, the overrides field
in package.json can control module resolution:
{\ { // highlight-start "overrides": { "xlsx": "https://cdn.sheetjs.com/xlsx-${current}/xlsx-${current}.tgz" } // highlight-end }}
:::
Vendoring
For general stability, "vendoring" modules is the recommended approach:
- Remove any existing dependency on a project named xlsx:
1) Download the tarball (xlsx-{current}.tgz) for the desired version. The current
   version is available at https://cdn.sheetjs.com/xlsx-{current}/xlsx-{current}.tgz
- 
Create a vendorsubfolder at the root of your project and move the tarball to that folder. Add it to your project repository.
- 
Install the tarball using a package manager: 
The package will be installed and accessible as xlsx.
Usage
The package supports CommonJS require and ESM import module systems.
:::info pass
It is strongly recommended to use CommonJS in NodeJS.
:::
CommonJS require
By default, the module supports require and it will automatically add support
for streams and file system access:
var XLSX = require("xlsx");
ESM import
The package also ships with xlsx.mjs, a script compatible with the ECMAScript
module system. When using the ESM build in NodeJS, some dependencies must be
loaded manually.
Filesystem Operations
The set_fs method accepts a fs instance for reading and writing files using
readFile and writeFile:
import * as XLSX from 'xlsx';
/* load 'fs' for readFile and writeFile support */
import * as fs from 'fs';
XLSX.set_fs(fs);
Stream Operations
The set_readable method accepts a stream.Readable instance for use in stream
methods such as XLSX.stream.to_csv:
import * as XLSX from 'xlsx';
/* load 'stream' for stream support */
import { Readable } from 'stream';
XLSX.stream.set_readable(Readable);
Encoding Support
The set_cptable method accepts an instance of the SheetJS codepage library for
use in legacy file format processing. The cpexcel.full.mjs script must be
manually loaded. xlsx/dist/cpexcel.full.mjs can be imported:
import * as XLSX from 'xlsx';
/* load the codepage support library for extended support with older formats  */
import * as cpexcel from 'xlsx/dist/cpexcel.full.mjs';
XLSX.set_cptable(cpexcel);
NextJS
:::warning pass
fs cannot be imported from the top level in NextJS pages. This will not work:
/* it is safe to import the library from the top level */
import { readFile, utils, set_fs } from 'xlsx';
/* it is not safe to import 'fs' from the top level ! */
// highlight-next-line
import * as fs from 'fs'; // this import will fail
set_fs(fs);
:::
For server-side file processing, fs should be loaded with a dynamic import
within a lifecycle function:
/* it is safe to import the library from the top level */
import { readFile, utils, set_fs } from 'xlsx';
import { join } from 'path';
import { cwd } from 'process';
export async function getServerSideProps() {
// highlight-next-line
  set_fs(await import("fs")); // dynamically import 'fs' in `getServerSideProps`
  const wb = readFile(join(cwd(), "public", "sheetjs.xlsx"));
  // ...
}
The NextJS demo includes complete examples.