google-spreadsheet
A fork of The most popular Google Sheets API wrapper for javascript / typescript
Differences from the original
- DeveloperMetadata is supported
- Retries are supported when rate limited
- Safer handling of numeric headers
- Support for providing valueRenderOption when loading rows & headers
- Support for reading cell & row metadata
- multiple auth options (via google-auth-library) - service account, OAuth, API key, ADC, etc
- cell-based API - read, write, bulk-updates, formatting
- row-based API - read, update, delete (based on the old v3 row-based calls)
- managing worksheets - add, remove, resize, update properties (ex: title), duplicate to same or other document
- managing docs - create new doc, delete doc, basic sharing/permissions
- export - download sheet/docs in various formats
Docs site -
Full docs available at https://theoephraim.github.io/node-google-spreadsheet
🌈 Installation - pnpm i google-spreadsheet
(or npm i google-spreadsheet --save
or yarn add google-spreadsheet
)
Examples
The following examples are meant to give you an idea of just some of the things you can do
IMPORTANT NOTE - To keep the examples concise, I'm calling await at the top level which is not allowed in some older versions of node. If you need to call await in a script at the root level and your environment does not support it, you must instead wrap it in an async function like so:
(async function () {
await someAsyncFunction();
})();
The Basics
import { GoogleSpreadsheet } from 'google-spreadsheet';
import { JWT } from 'google-auth-library';
const serviceAccountAuth = new JWT({
email: process.env.GOOGLE_SERVICE_ACCOUNT_EMAIL,
key: process.env.GOOGLE_PRIVATE_KEY,
scopes: ['https://www.googleapis.com/auth/spreadsheets'],
});
const doc = new GoogleSpreadsheet('<the sheet ID from the url>', serviceAccountAuth);
await doc.loadInfo();
console.log(doc.title);
await doc.updateProperties({ title: 'renamed doc' });
const sheet = doc.sheetsByIndex[0];
console.log(sheet.title);
console.log(sheet.rowCount);
const newSheet = await doc.addSheet({ title: 'another sheet' });
await newSheet.delete();
More info:
Working with rows
const sheet = await doc.addSheet({ headerValues: ['name', 'email'] });
const larryRow = await sheet.addRow({ name: 'Larry Page', email: 'larry@google.com' });
const moreRows = await sheet.addRows([
{ name: 'Sergey Brin', email: 'sergey@google.com' },
{ name: 'Eric Schmidt', email: 'eric@google.com' },
]);
const rows = await sheet.getRows();
console.log(rows[0].get('name'));
rows[1].set('email', 'sergey@abc.xyz');
rows[2].assign({ name: 'Sundar Pichai', email: 'sundar@google.com' });
await rows[2].save();
await rows[2].delete();
Row methods support explicit TypeScript types for shape of the data
type UsersRowData = {
name: string;
email: string;
type?: 'admin' | 'user';
};
const userRows = await sheet.getRows<UsersRowData>();
userRows[0].get('name');
userRows[0].get('badColumn');
More info:
Working with cells
await sheet.loadCells('A1:E10');
console.log(sheet.cellStats);
const a1 = sheet.getCell(0, 0);
const c6 = sheet.getCellByA1('C6');
console.log(a1.value);
console.log(a1.formula);
console.log(a1.formattedValue);
a1.value = 123.456;
c6.formula = '=A1';
a1.textFormat = { bold: true };
c6.note = 'This is a note!';
await sheet.saveUpdatedCells();
More info:
Managing docs and sharing
const auth = new JWT({
email: process.env.GOOGLE_SERVICE_ACCOUNT_EMAIL,
key: process.env.GOOGLE_PRIVATE_KEY,
scopes: [
'https://www.googleapis.com/auth/spreadsheets',
'https://www.googleapis.com/auth/drive.file',
],
});
const newDoc = await GoogleSpreadsheet.createNewSpreadsheetDocument(auth, { title: 'new fancy doc' });
await newDoc.share('someone.else@example.com');
await newDoc.share('mycorp.com');
await newDoc.setPublicAccessLevel('reader');
await newDoc.delete();
Why?
This module provides an intuitive wrapper around Google's API to simplify common interactions
While Google's v4 sheets API is much easier to use than v3 was, the official googleapis npm module is a giant autogenerated meta-tool that handles every Google product. The module and the API itself are awkward and the docs are pretty terrible, at least to get started.
In what situation should you use Google's API directly?
This module makes trade-offs for simplicity of the interface.
Google's API provides a mechanism to make many requests in parallel, so if speed and efficiency are extremely important to your use case, you may want to use their API directly. There are also many lesser-used features of their API that are not implemented here yet.
Support & Contributions
This module was written and is actively maintained by Theo Ephraim.
Are you actively using this module for a commercial project? Want to help support it?
Buy Theo a beer
None yet - get in touch!
Contributing
Contributions are welcome, but please follow the existing conventions, use the linter, add relevant tests, and add relevant documentation.
The docs site is generated using docsify. To preview and run locally so you can make edits, run npm run docs:preview
and head to http://localhost:3000
The content lives in markdown files in the docs folder.
License
This is free and unencumbered public domain software. For more info, see https://unlicense.org.