UNPKG

@devbaygroup/googlesheet

Version:

implement from https://github.com/theoephraim/node-google-spreadsheet

148 lines (107 loc) 6.74 kB
implement from https://github.com/theoephraim/node-google-spreadsheet # google-spreadsheet > The most popular [Google Sheets API](https://developers.google.com/sheets/api/reference/rest) wrapper for javascript [//]: # () [//]: # ([![NPM version]&#40;https://img.shields.io/npm/v/google-spreadsheet&#41;]&#40;https://www.npmjs.com/package/google-spreadsheet&#41;) [//]: # ([![CircleCI]&#40;https://circleci.com/gh/theoephraim/node-google-spreadsheet.svg?style=shield&#41;]&#40;https://circleci.com/gh/theoephraim/node-google-spreadsheet&#41;) [//]: # ([![Known Vulnerabilities]&#40;https://snyk.io/test/github/theoephraim/node-google-spreadsheet/badge.svg?targetFile=package.json&#41;]&#40;https://snyk.io/test/github/theoephraim/node-google-spreadsheet?targetFile=package.json&#41;) [//]: # ([![NPM]&#40;https://img.shields.io/npm/dw/google-spreadsheet&#41;]&#40;https://www.npmtrends.com/google-spreadsheet&#41;) - multiple auth options - service account (w/ optional impersonation), OAuth 2.0, API key (read-only) - cell-based API - read, write, bulk-updates, formatting - row-based API - read, update, delete (based on v4 row-based calls) - managing worksheets - add, remove, resize, change title, formatting ------------- > 🌈 **Installation** - `npm i googlesheet --save` or `yarn add googlesheet` ## 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](https://v8.dev/features/top-level-await) which is not allowed by default in most versions of node. If you need to call await in a script at the root level, you must instead wrap it in an async function like so: ```javascript (async function() { await someAsyncFunction(); }()); ``` ### The Basics ```javascript const { GoogleSpreadsheet } = require('google-spreadsheet'); // Initialize the sheet - doc ID is the long id in the sheets URL const doc = new GoogleSpreadsheet('<the sheet ID from the url>'); // Initialize Auth - see https://theoephraim.github.io/node-google-spreadsheet/#/getting-started/authentication await doc.useServiceAccountAuth({ // env var values are copied from service account credentials generated by google // see "Authentication" section in docs for more info client_email: process.env.GOOGLE_SERVICE_ACCOUNT_EMAIL, private_key: process.env.GOOGLE_PRIVATE_KEY, }); await doc.loadInfo(); // loads document properties and worksheets console.log(doc.title); await doc.updateProperties({ title: 'renamed doc' }); const sheet = doc.sheetsByIndex[0]; // or use doc.sheetsById[id] or doc.sheetsByTitle[title] console.log(sheet.title); console.log(sheet.rowCount); // adding / removing sheets const newSheet = await doc.addSheet({ title: 'hot new sheet!' }); await newSheet.delete(); ``` More info: - [GoogleSpreadsheet](https://theoephraim.github.io/node-google-spreadsheet/#/classes/google-spreadsheet) - [GoogleSpreadsheetWorksheet](https://theoephraim.github.io/node-google-spreadsheet/#/classes/google-spreadsheet-worksheet) - [Authentication](https://theoephraim.github.io/node-google-spreadsheet/#/getting-started/authentication) ### Working with rows ```javascript // create a sheet and set the header row const sheet = await doc.addSheet({ headerValues: ['name', 'email'] }); // append rows 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' }, ]); // read rows const rows = await sheet.getRows(); // can pass in { limit, offset } // read/write row values console.log(rows[0].name); // 'Larry Page' rows[1].email = 'sergey@abc.xyz'; // update a value await rows[1].save(); // save updates await rows[1].delete(); // delete a row ``` More info: - [GoogleSpreadsheetWorksheet > Working With Rows](https://theoephraim.github.io/node-google-spreadsheet/#/classes/google-spreadsheet-worksheet#working-with-rows) - [GoogleSpreadsheetRow](https://theoephraim.github.io/node-google-spreadsheet/#/classes/google-spreadsheet-row) ### Working with cells ```javascript await sheet.loadCells('A1:E10'); // loads range of cells into local cache - DOES NOT RETURN THE CELLS console.log(sheet.cellStats); // total cells, loaded, how many non-empty const a1 = sheet.getCell(0, 0); // access cells using a zero-based index const c6 = sheet.getCellByA1('C6'); // or A1 style notation // access everything about the cell console.log(a1.value); console.log(a1.formula); console.log(a1.formattedValue); // update the cell contents and formatting a1.value = 123.456; c6.formula = '=A1'; a1.textFormat = { bold: true }; c6.note = 'This is a note!'; await sheet.saveUpdatedCells(); // save all updates in one call ``` More info: - [GoogleSpreadsheetWorksheet > Working With Cells](https://theoephraim.github.io/node-google-spreadsheet/#/classes/google-spreadsheet-worksheet#working-with-cells) - [GoogleSpreadsheetCell](https://theoephraim.github.io/node-google-spreadsheet/#/classes/google-spreadsheet-cell) ## 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](https://www.npmjs.com/package/googleapis) is a giant 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?**<br> 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 is extremely important to your use case, you may want to use their API directly. There are also several features of their API that are not implemented here yet. ## Support & Contributions This module was written and is actively maintained by [Theo Ephraim](https://theoephraim.com). **Are you actively using this module for a commercial project? Want to help support it?**<br> [Buy Theo a beer](https://paypal.me/theoephraim) #### Sponsors None yet - get in touch! #### Contributing Contributions are welcome, but please follow the existing conventions, use the linter, add relevant tests, add relevant documentation. The docs site is generated using [docsify](https://docsify.js.org). 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.