A clean, interactive Google Sheet explorer for Colab (Jadwal)
Project description
ipyjadwal 📊
ipyjadwal (derived from the Arabic Jadwal جَدْوَل meaning "Table" or "Schedule") is a clean, interactive Jupyter widget for browsing Google Sheets directly inside Google Colab or Jupyter Notebooks.
It simplifies the workflow of selecting spreadsheets, switching sheets, and previewing DataFrames without writing repetitive boilerplate code.
Installation
pip install ipyjadwal
Usage
import ipyjadwal
widget = ipyjadwal.Jadwal()
widget.show()
# Access selected data as pandas DataFrame
df = widget.df
# Write updates back using gspread
widget.sheet.update_cell(1, 1, "New Value")
For local Jupyter Notebooks, provide a gspread client:
import gspread
import ipyjadwal
gc = gspread.service_account("credentials.json")
widget = ipyjadwal.Jadwal(client=gc)
widget.show()
✨ Features
-
🔍 Interactive Dropdown
Browse all your Google Drive spreadsheets through a clean, searchable dropdown interface. -
📑 Seamless Sheet Navigation
Automatically loads and displays all available worksheets when you select a spreadsheet—no manual loading required. -
🐼 Live DataFrame Preview
Instantly preview your data as a pandas DataFrame with automatic updates as you switch between sheets. -
📊 Full Data Access
Access the complete sheet data viawidget.dffor analysis, transformations, and visualization. -
✏️ Full gspread Access
Access all gspread functionality viawidget.sheet(e.g., update cells, append rows, format ranges). -
🔄 One-Click Refresh
Reload your file list or refresh sheet data with a single button click. -
🔀 Flexible Sorting
Sort spreadsheets by name (ascending/descending) or leave untouched to preserve Google Sheets' default order. -
🎯 Zero Boilerplate
Skip repetitive setup code—import, instantiate, and start exploring your data immediately.
🔧 Documentation
API Reference
Jadwal(client=None, sort_method="default")
Main widget class for browsing Google Sheets.
Parameters
client(optional): An authorized gspread client. IfNone, attempts automatic authentication in Google Colab.sort_method:"default"(default),"asc", or"dsc"— Sort order for the file list.
Properties
df: pandas DataFrame containing the full data from the currently selected sheet.sheet: gspread worksheet object for the currently selected sheet — use this to write back to Google Sheets.
Methods
show(): Display the interactive widget.
Links
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Built with gspread for Google Sheets API
- Powered by ipywidgets for interactive UI
Project details
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 ipyjadwal-0.1.5.tar.gz.
File metadata
- Download URL: ipyjadwal-0.1.5.tar.gz
- Upload date:
- Size: 5.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e2d66dd4b6f4fc46e36642bab7e8a58fc7966268293f5ce21ecbddced9737d10
|
|
| MD5 |
1292bd17cc48115082caa6d957983366
|
|
| BLAKE2b-256 |
5803d7e0cda1b9b2d260b9bb94c039a1beb62fe3c5fa1a0146a4b4e6764b2248
|
Provenance
The following attestation bundles were made for ipyjadwal-0.1.5.tar.gz:
Publisher:
publish.yml on marzzuki/ipyjadwal
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ipyjadwal-0.1.5.tar.gz -
Subject digest:
e2d66dd4b6f4fc46e36642bab7e8a58fc7966268293f5ce21ecbddced9737d10 - Sigstore transparency entry: 779988198
- Sigstore integration time:
-
Permalink:
marzzuki/ipyjadwal@177423da3c7b7e133bef6959bf95d9c0e3677a53 -
Branch / Tag:
refs/tags/v.0.1.5 - Owner: https://github.com/marzzuki
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@177423da3c7b7e133bef6959bf95d9c0e3677a53 -
Trigger Event:
release
-
Statement type:
File details
Details for the file ipyjadwal-0.1.5-py3-none-any.whl.
File metadata
- Download URL: ipyjadwal-0.1.5-py3-none-any.whl
- Upload date:
- Size: 5.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
35a6fdf7aafc0c4cd62621b63c6bebf787b35df3f37a4c9d87b6bcd227aa6534
|
|
| MD5 |
a686fc616185a3fc7646df106451765e
|
|
| BLAKE2b-256 |
f87a4e8618b86c0243b5a074bc600078cb5d827bd4eb0780f0c9cfaff63aa0a1
|
Provenance
The following attestation bundles were made for ipyjadwal-0.1.5-py3-none-any.whl:
Publisher:
publish.yml on marzzuki/ipyjadwal
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ipyjadwal-0.1.5-py3-none-any.whl -
Subject digest:
35a6fdf7aafc0c4cd62621b63c6bebf787b35df3f37a4c9d87b6bcd227aa6534 - Sigstore transparency entry: 779988200
- Sigstore integration time:
-
Permalink:
marzzuki/ipyjadwal@177423da3c7b7e133bef6959bf95d9c0e3677a53 -
Branch / Tag:
refs/tags/v.0.1.5 - Owner: https://github.com/marzzuki
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@177423da3c7b7e133bef6959bf95d9c0e3677a53 -
Trigger Event:
release
-
Statement type: