GoogleSheetsWrapper 1.0.14

There is a newer version of this package available.
See the version list below for details.
dotnet add package GoogleSheetsWrapper --version 1.0.14
NuGet\Install-Package GoogleSheetsWrapper -Version 1.0.14
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="GoogleSheetsWrapper" Version="1.0.14" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add GoogleSheetsWrapper --version 1.0.14
#r "nuget: GoogleSheetsWrapper, 1.0.14"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install GoogleSheetsWrapper as a Cake Addin
#addin nuget:?package=GoogleSheetsWrapper&version=1.0.14

// Install GoogleSheetsWrapper as a Cake Tool
#tool nuget:?package=GoogleSheetsWrapper&version=1.0.14

GoogleSheetsWrapper

Nuget GitHub build status

Google Sheets API .NET Wrapper Library

This library allows you to use strongly typed objects against a Google Sheets spreadsheet without having to have knowledge on the Google Sheets API methods and protocols.

The following Google Sheets API operations are supported:

  • Reading all rows
  • Appending new rows
  • Deleting rows
  • Updating specific cells

All operations above are encapsulated in the SheetHelper class.

There are also base classes, BaseRecord and BaseRepository to simplify transforming raw Google Sheets rows into .NET objects.

Extend BaseRecord and BaseRepository

Extending the BaseRecord class you can decorate properties with the SheetFieldAttribute to describe the column header name, the column index and the field type (ie string, DateTime, etc)

The column index is 1 based and not 0 based. The first colum 'A' is equivalent to the column ID of 1.

public class TestRecord : BaseRecord
{
    [SheetField(
        DisplayName = "Name",
        ColumnID = 1,
        FieldType = SheetFieldType.String)]
    public string Name { get; set; }

    [SheetField(
        DisplayName = "Number",
        ColumnID = 2,
        FieldType = SheetFieldType.PhoneNumber)]
    public long PhoneNumber { get; set; }

    [SheetField(
        DisplayName = "Price Amount",
        ColumnID = 3,
        FieldType = SheetFieldType.Currency)]
    public double PriceAmount { get; set; }

    [SheetField(
        DisplayName = "Date",
        ColumnID = 4,
        FieldType = SheetFieldType.DateTime)]
    public DateTime DateTime { get; set; }

    [SheetField(
        DisplayName = "Quantity",
        ColumnID = 5,
        FieldType = SheetFieldType.Number)]
    public double Quantity { get; set; }

    public TestRecord() { }

    public TestRecord(IList<object> row, int rowId) : base(row, rowId) { }
}

Extending the BaseRepository allows you to define your own access layer to the Google Sheets tab you want to work with.

public class TestRepository : BaseRepository<TestRecord>
{
    public TestRepository() { }

    public TestRepository(SheetHelper<TestRecord> sheetsHelper)
        : base(sheetsHelper) { }
}

Core Operations

Before you run the following code you will need to setup a Google Service Account and create a service account key. You also need to decide how to store your environment variables and secrets (ie the Google service account key)

More details can be found here

// You need to implement your own configuration management solution here!
var settings = AppSettings.FromEnvironment();

// Create a SheetHelper class for the specified Google Sheet and Tab name
var sheetHelper = new SheetHelper<TestRecord>(
    settings.GoogleSpreadsheetId,
    settings.GoogleServiceAccountName,
    settings.GoogleMainSheetName);

sheetHelper.Init(settings.JsonCredential);

// Create a Repository for the TestRecord class
var repository = new TestRepository(sheetHelper);

// Validate that the header names match the expected format defined with the SheetFieldAttribute values
var result = repository.ValidateSchema();

if(!result.IsValid)
{
    throw new ArgumentException(result.ErrorMessage);
}

// Get all rows from the Google Sheet
var allRecords = repository.GetAllRecords();

// Get the first record
var firstRecord = allRecords.First();

// Update the PriceAmount field and save it back to Google Sheets
firstRecord.PriceAmount = 99.99;
repository.SaveField(firstRecord, (r) => r.PriceAmount);

// Delete the first record from Google Sheets
repository.DeleteRecord(firstRecord);

// Add a new record to the end of the Google Sheets tab
repository.AddRecord(new TestRecord()
{
    Name = "John",
    Number = 2021112222,
    PriceAmount = 250.50,
    Date = DateTime.Now(),
    Quantity = 123
});

Export Google Sheet to CSV

var exporter = new SheetExporter(
    settings.GoogleSpreadsheetId, 
    settings.GoogleServiceAccountName, 
    settings.GoogleMainSheetName);

exporter.Init(settings.JsonCredential);

var filepath = @"C:\Output\output.csv";

using (var stream = new FileStream(filepath))
{
    // Query the range A1:G (ie 1st column, 1st row, 8th column and last row in the sheet)
    var range = new SheetRange("TAB_NAME", 1, 1, 8);
    exporter.ExportAsCsv(range, writer);
}

Export Google Sheet to Excel File

var exporter = new SheetExporter(
    settings.GoogleSpreadsheetId, 
    settings.GoogleServiceAccountName, 
    settings.GoogleMainSheetName);

exporter.Init(settings.JsonCredential);

var filepath = @"C:\Output\output.xlsx";

using (var stream = new FileStream(filepath))
{
    // Query the range A1:G (ie 1st column, 1st row, 8th column and last row in the sheet)
    var range = new SheetRange("TAB_NAME", 1, 1, 8);
    exporter.ExportAsExcel(range, writer);
}

Authentication

You need to setup a Google API Service Account before you can use this library.

  1. Create a service account. Steps to do that are documented below,

    https://cloud.google.com/docs/authentication/production#create_service_account

  2. After you download the JSON key, you need to decide how you want to store it and load it into the application.

  3. Use the service account identity that is created and add that email address to grant it permissions to the Google Sheets Spreadsheet you want to interact with.

  4. Configure your code with the following parameters to initialize a SheetHelper object

// You need to implement your own configuration management solution here!
var settings = AppSettings.FromEnvironment();

// Create a SheetHelper class for the specified Google Sheet and Tab name
var sheetHelper = new SheetHelper<TestRecord>(
    settings.GoogleSpreadsheetId,
    settings.GoogleServiceAccountName,
    settings.GoogleMainSheetName);

sheetHelper.Init(settings.JsonCredential);
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.11 273 1/20/2024
2.0.10 82 1/20/2024
2.0.9 1,197 1/8/2024
2.0.8 93 1/6/2024
2.0.7 93 1/6/2024
2.0.6 185 12/19/2023
2.0.5 230 11/28/2023
2.0.4 286 11/26/2023
2.0.3 96 11/25/2023
2.0.2 108 11/14/2023
2.0.1 81 11/14/2023
2.0.0 87 11/13/2023
1.0.58 1,457 11/13/2023
1.0.57 115 11/6/2023
1.0.56 100 11/6/2023
1.0.55 142 10/21/2023
1.0.54 1,334 5/9/2023
1.0.53 135 5/6/2023
1.0.52 46,986 2/7/2023
1.0.51 1,512 1/1/2023
1.0.50 260 12/29/2022
1.0.49 285 11/28/2022
1.0.48 278 11/28/2022
1.0.47 288 11/28/2022
1.0.46 284 11/28/2022
1.0.45 287 11/28/2022
1.0.44 304 11/22/2022
1.0.43 292 11/22/2022
1.0.42 292 11/22/2022
1.0.41 292 11/22/2022
1.0.40 309 11/22/2022
1.0.39 367 11/20/2022
1.0.38 282 11/19/2022
1.0.37 583 8/25/2022
1.0.36 383 8/18/2022
1.0.35 474 8/2/2022
1.0.34 380 6/18/2022
1.0.33 485 5/19/2022
1.0.32 377 5/17/2022
1.0.31 619 3/8/2022
1.0.30 405 3/8/2022
1.0.29 416 1/19/2022
1.0.28 275 12/20/2021
1.0.27 433 10/31/2021
1.0.26 279 10/28/2021
1.0.25 294 10/26/2021
1.0.24 318 10/17/2021
1.0.23 360 10/17/2021
1.0.22 322 10/16/2021
1.0.21 364 9/12/2021
1.0.20 384 8/26/2021
1.0.19 298 8/25/2021
1.0.18 283 8/25/2021
1.0.17 305 8/22/2021
1.0.16 295 8/22/2021
1.0.15 284 8/22/2021
1.0.14 302 8/21/2021
1.0.13 318 8/21/2021
1.0.12 304 8/21/2021
1.0.11 273 8/21/2021
1.0.10 279 8/21/2021
1.0.9 280 8/11/2021
1.0.8 278 8/9/2021
1.0.7 294 8/9/2021
1.0.6 314 8/8/2021
1.0.5 290 8/6/2021
1.0.4 302 8/5/2021
1.0.3 311 8/3/2021
1.0.2 307 8/3/2021
1.0.1 353 8/1/2021
1.0.0 276 8/1/2021