Python client for Singapore government open data (data.gov.sg, LTA, OneMap)
Project description
publicsgdata
Python client for Singapore government open data: data.gov.sg today, LTA and OneMap later.
Install
Requires uv.
uv pip install publicsgdata
Quickstart
from publicsgdata import DataGovSGClient
with DataGovSGClient() as client: # optional: api_key="..." or DATA_GOV_SG_API_KEY
catalog = client.collections.list()
print(f"{len(catalog.collections)} collections")
print(catalog.collections[0].name)
# HDB resale prices (swap in any dataset ID)
rows = client.datasets.list_rows("d_8b84c4ee58e3cfc0ece0d773c8ca6abc", limit=10)
for row in rows.rows:
print(row.model_dump())
pm25 = client.realtime.pm25.get()
print(pm25.items[0].readings)
Async
from publicsgdata import AsyncDataGovSGClient
async with AsyncDataGovSGClient() as client:
rows = await client.datasets.list_rows("d_8b84c4ee58e3cfc0ece0d773c8ca6abc", limit=5)
print(len(rows.rows))
Custom HTTP client
Pass your own httpx client if you need custom timeouts, proxies, etc.
import httpx
from publicsgdata import DataGovSGClient
with httpx.Client(timeout=30.0) as http:
client = DataGovSGClient(http_client=http)
print(len(client.collections.list().collections))
Authentication
You can call the API without a key while experimenting. For regular use, get a key from data.gov.sg and set:
export DATA_GOV_SG_API_KEY="your-key"
Environment variables
| Variable | Required | Description |
|---|---|---|
DATA_GOV_SG_API_KEY |
No | data.gov.sg API key (x-api-key header) |
Development
You'll need uv.
./scripts/dev_setup.sh # creates .venv from uv.lock
./scripts/format.sh
./scripts/validate.sh
./scripts/test.sh # unit tests, runs in CI
./scripts/test_integration.sh # hits the real API, local only
Or run things directly: uv run pytest, uv run ruff check ., etc.
See CONTRIBUTING.md if you're opening a PR.
Roadmap
- v0.1.0:
DataGovSGClient - v0.2.0:
LTAClient(LTA DataMall) - v0.3.0:
OneMapClient
License
MIT. See LICENSE.
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 publicsgdata-0.1.1.tar.gz.
File metadata
- Download URL: publicsgdata-0.1.1.tar.gz
- Upload date:
- Size: 11.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5e21bb1c3e2b9b34fe91ab0b1ae22fc8e173d48f4cfa65fdfd3c9ba6b28cc53d
|
|
| MD5 |
1be826d97c4d01fe12f0a68233a468d1
|
|
| BLAKE2b-256 |
d2ad7a6283777a51cccf34a78d745aad10fb71fd9c3494dc2d39e5a1a7b71234
|
File details
Details for the file publicsgdata-0.1.1-py3-none-any.whl.
File metadata
- Download URL: publicsgdata-0.1.1-py3-none-any.whl
- Upload date:
- Size: 15.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
459f814f5f657e8fb784a22937af0f000ab79434d9e20b3d58a3c1c554ddc121
|
|
| MD5 |
46d90a64aa43720cb7853a37b8666912
|
|
| BLAKE2b-256 |
a48b2b52eee8995b082f0ba9f6fed6fb76fb3fe555b9e6b2deed446bea946bb5
|