Enhanced Google Sheets operations with advanced data type handling
Project description
gspreadplusplus
A Python library that enhances Google Sheets operations with additional functionality and improved data type handling.
Features
- Transfer Spark DataFrames to Google Sheets with proper type conversion
- Intelligent handling of various data types (numbers, dates, timestamps, etc.)
- Preserve or update sheet headers
- Selective column clearing options
- Automatic date formatting
- Sheet dimension management
- Configuration management with key-value storage
Installation
pip install gspreadplusplus
Requirements
- Python 3.7+
- gspread
- pyspark
- google-auth
Usage
Basic DataFrame Export
from gspreadplusplus import GPP
from pyspark.sql import SparkSession
# Initialize Spark and create a DataFrame
spark = SparkSession.builder.appName("example").getOrCreate()
df = spark.createDataFrame([
("2024-01-01", 100, "Complete"),
("2024-01-02", 150, "Pending")
], ["date", "amount", "status"])
# Your Google Sheets credentials
creds_json = {
"type": "service_account",
# ... rest of your service account credentials
}
# Export DataFrame to Google Sheets
GPP.df_to_sheets(
df=df,
spreadsheet_id="your_spreadsheet_id",
sheet_name="Sheet1",
creds_json=creds_json
)
Advanced DataFrame Export Options
GPP.df_to_sheets(
df=df,
spreadsheet_id="your_spreadsheet_id",
sheet_name="Sheet1",
creds_json=creds_json,
english_locale=True, # Use '.' as decimal separator
keep_header=True, # Preserve existing header row
erase_whole=False # Clear only necessary columns
)
Configuration Management
The library provides functionality to store and update configuration values in a Google Sheet. By default, it uses a sheet named "CONFIG" with keys in column A and values in column B.
# Store or update a configuration value
result = GPP.set_config(
spreadsheet_id="your_spreadsheet_id",
key="api_endpoint",
value="https://api.example.com",
creds_json=creds_json,
sheet_name="CONFIG" # Optional, defaults to "CONFIG"
)
if result == 0:
print("Configuration updated successfully")
else:
print("Error updating configuration")
The set_config function will:
- Search for the key in column A
- If found, update the corresponding value in column B
- If not found, append a new row with the key-value pair
- Return 0 on success, 1 on error
Data Type Support
The library automatically handles conversion of various data types:
- Strings
- Integers (regular, long, bigint)
- Floating point numbers (double, float)
- Decimals
- Dates
- Timestamps
- Booleans
Null values are converted to:
- 0 for numeric types
- Empty string for other types
Error Handling
The library implements comprehensive error handling:
- Returns status codes for operations (0 for success, 1 for failure)
- Prints detailed error messages for debugging
- Gracefully handles missing keys, sheet access issues, and credential problems
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gspreadplusplus-2.1.2.tar.gz.
File metadata
- Download URL: gspreadplusplus-2.1.2.tar.gz
- Upload date:
- Size: 5.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f21de8efa3febe9a2b85ad5c87d469944e676be927919ac2a94ace58a0dda90e
|
|
| MD5 |
516d6fc654d633e4424b9355d80bacd6
|
|
| BLAKE2b-256 |
8e39129453fef1f59c3bc0846dbd7384d34fde35054fe1f9651f804fd6d55d5d
|
File details
Details for the file gspreadplusplus-2.1.2-py3-none-any.whl.
File metadata
- Download URL: gspreadplusplus-2.1.2-py3-none-any.whl
- Upload date:
- Size: 5.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1668531c64ae7a5444d8ab77aecc010fa86948e2134cc337764b4c988a626a88
|
|
| MD5 |
95a2a31759a4a356cbd7da7119af4755
|
|
| BLAKE2b-256 |
ea9dca7e19db47891ba01ec7985143b45f773ed7dcbf0196dca982bacb429455
|