Terminal UI untuk menjelajahi dan mengunduh data BPS Indonesia secara interaktif
Project description
STADATA-X
Membuka Data Statistik Indonesia, Satu Perintah Sekaligus.
stadata-x adalah sebuah aplikasi terminal (TUI) modern yang dirancang untuk menjelajahi, melihat, dan mengunduh data dari Badan Pusat Statistik (BPS) Indonesia secara interaktif. Dibangun dengan Python dan Textual, aplikasi ini menyediakan antarmuka yang cepat dan efisien untuk mengakses kekayaan data publik BPS langsung dari command line Anda.
Lupakan mengunduh file secara manual. Dengan stadata-x, Anda dapat dengan mudah menavigasi data berdasarkan wilayah, mencari tabel statistik, melihat pratinjau, dan mengunduhnya dalam berbagai format (CSV, Excel, JSON).
๐ธ Screenshots
Layar Selamat Datang
Pemilihan Wilayah
โจ Fitur Utama
- ๐ฏ Navigasi Interaktif: Jelajahi data BPS berdasarkan wilayah (Provinsi/Kabupaten/Kota) melalui antarmuka yang responsif.
- ๐ Pratinjau Tabel: Lihat isi tabel statistik langsung di terminal sebelum mengunduh, dengan pewarnaan dan perataan kolom otomatis untuk keterbacaan maksimal.
- ๐ฅ Unduhan Multi-Format: Unduh data yang Anda butuhkan dalam format CSV, Excel (.xlsx), atau JSON.
- โ๏ธ Manajemen Konfigurasi: Simpan Token API BPS dan atur folder unduhan default dengan mudah.
- ๐ Penanganan Error Cerdas: Dilengkapi dengan mekanisme retry otomatis untuk mengatasi rate limiting API dan penanganan error koneksi yang tangguh.
- ๐ Caching: Permintaan data yang sering diakses (seperti daftar wilayah) disimpan dalam cache untuk mempercepat waktu muat.
- ๐จ Antarmuka Modern: Pengalaman pengguna yang mulus dan modern di dalam terminal Anda.
๐ Persyaratan Sistem
- Python: 3.9 atau yang lebih baru
- Terminal: Terminal modern yang mendukung ANSI colors (Windows Terminal, iTerm2, GNOME Terminal, dll.)
- Token API BPS: Diperlukan untuk mengakses data (gratis dari portal developer BPS)
๐ Status & Coverage
- โ 113 Tests Passed - Test suite lengkap dengan coverage tinggi
- โ Cross-platform - Kompatibel Windows, Linux, dan macOS (Python 3.9-3.13)
- โ CI/CD Active - GitHub Actions dengan testing multi-platform
- โ
PyPI Published - Tersedia untuk instalasi global via
pip install stadata-x
๐ Instalasi
Pastikan Anda memiliki Python 3.9 atau yang lebih baru. stadata-x dapat diinstal dengan mudah menggunakan pip, pipx, atau uv.
Menggunakan pipx (Direkomendasikan)
pipx menginstal paket Python dalam lingkungan terisolasi, yang merupakan cara terbaik untuk menginstal aplikasi command-line.
pipx install stadata-x
Menggunakan pip
pip install stadata-x
Menggunakan uv
uv pip install stadata-x
Verifikasi Instalasi
Setelah instalasi, verifikasi bahwa aplikasi terinstal dengan benar:
stadata-x --version
๐ง Troubleshooting
Masalah Instalasi Umum
1. Build Error dengan lxml
Error: fatal error C1083: Cannot open include file: 'libxml/xmlversion.h'
Solusi:
# Gunakan wheel-only installation
pip install stadata-x --only-binary=all
# Atau gunakan uv
uv pip install stadata-x --only-binary=all
Penjelasan: stadata-x menggunakan lxml>=6.0.0 yang sudah include libxml2 binaries.
2. Python Version Compatibility
Error: TypeError: unsupported operand type(s) for |: 'type' and 'NoneType'
Solusi:
- Pastikan menggunakan Python 3.9 atau yang lebih baru
stadata-xmendukung Python 3.9-3.13
3. Permission Error (Windows)
Error: PermissionError: [Errno 13] Permission denied
Solusi:
# Jalankan sebagai administrator atau gunakan virtual environment
python -m venv venv
venv\Scripts\activate
pip install stadata-x
4. SSL/Connection Error
Error: ssl.SSLCertVerificationError atau connection timeout
Solusi:
# Update pip dan certificates
pip install --upgrade pip certifi
# Atau gunakan HTTP instead HTTPS
pip install stadata-x --trusted-host pypi.org --trusted-host files.pythonhosted.org
5. Dependency Conflict
Error: ERROR: Cannot install stadata-x because these package versions have conflicting dependencies
Solusi:
# Gunakan virtual environment terisolasi
python -m venv isolated_env
isolated_env\Scripts\activate
pip install stadata-x
# Atau gunakan pip-tools untuk resolve dependencies
pip install pip-tools
pip-compile --output-file=requirements.txt pyproject.toml
pip-sync
Alternative Installation Methods
Menggunakan Conda (Windows Recommended)
# Install Miniconda atau Anaconda
# Buat environment baru
conda create -n stadata-env python=3.11
conda activate stadata-env
# Install package
pip install stadata-x
Menggunakan pipx (Isolated Environment)
pipx install stadata-x
Manual Installation dari Source
# Clone repository
git clone https://github.com/dzakwanalifi/stadata-x.git
cd stadata-x
# Install dengan uv
uv sync --dev
uv run stadata-x --version
Debug dan Logging
Enable Verbose Output
# Untuk pip
pip install stadata-x -v
# Untuk uv
uv pip install stadata-x --verbose
Check System Information
# Python version
python --version
# pip version
pip --version
# OS information
python -c "import platform; print(platform.platform())"
# Check installed packages
pip list | grep -E "(stadata|lxml|textual)"
Masalah Runtime
API Token Error
ApiTokenError: Token API tidak diatur
Solusi:
- Jalankan
stadata-x - Tekan
suntuk Settings - Masukkan Token API BPS Anda
- Test koneksi dengan tombol "Tes Koneksi"
Network/Connection Error
NoInternetError: Tidak ada koneksi internet
Solusi:
- Check koneksi internet
- Coba lagi dalam beberapa saat (rate limiting)
- Gunakan VPN jika diperlukan
Cache Issues
# Clear cache
# Windows
rmdir /s %USERPROFILE%\.stadata-x
# Linux/Mac
rm -rf ~/.stadata-x
Getting Help
Jika masalah berlanjut:
- Check GitHub Issues: https://github.com/dzakwanalifi/stadata-x/issues
- Create New Issue: Sertakan:
- Python version (
python --version) - OS information
- Full error traceback
- Installation method used
- Python version (
- Contact: dzakwan624@gmail.com
โก Quick Start
-
Konfigurasi Token API BPS:
stadata-x # Tekan 's' untuk masuk ke pengaturan # Tempel token API BPS Anda
-
Jelajahi Data:
stadata-x # Pilih wilayah โ Pilih tabel โ Lihat pratinjau โ Unduh
Konfigurasi Awal: API Key BPS
Untuk menggunakan aplikasi ini, Anda memerlukan Token API dari BPS. Token ini gratis dan berfungsi sebagai kunci untuk mengakses data.
Cara Mendapatkan Token API
- Kunjungi Portal WebAPI BPS: Buka webapi.bps.go.id/developer/.
- Daftar/Masuk: Buat akun baru atau masuk jika Anda sudah memilikinya.
- Salin Token: Setelah masuk, salin Token API yang ditampilkan di dashboard Anda.
- Konfigurasi di
stadata-x:- Jalankan aplikasi:
stadata-x - Tekan
suntuk masuk ke menu Pengaturan. - Tempel Token API Anda, lalu simpan.
- Gunakan tombol "Tes Koneksi" untuk memvalidasi token Anda.
- Jalankan aplikasi:
Penggunaan
Jalankan aplikasi dari terminal Anda:
stadata-x
โจ๏ธ Navigasi Dasar
| Tombol | Fungsi |
|---|---|
โ/โ atau j/k |
Bergerak di dalam daftar |
Enter |
Pilih item (wilayah atau tabel) |
Escape |
Kembali ke level sebelumnya |
s |
Buka halaman Pengaturan |
d |
Buka dialog unduhan (saat di pratinjau tabel) |
q |
Keluar dari aplikasi |
๐ Struktur Proyek
stadata-x/
โโโ stadata_x/ # Kode aplikasi utama
โ โโโ assets/ # CSS dan asset statis
โ โโโ screens/ # Layar-layar aplikasi
โ โโโ widgets/ # Komponen UI kustom
โ โโโ *.py # Modul utama
โโโ assets/ # Screenshot dan gambar dokumentasi
โโโ .gitignore # File yang diabaikan Git
โโโ LICENSE # Lisensi MIT
โโโ pyproject.toml # Konfigurasi proyek Python
โโโ README.md # Dokumentasi ini
๐ค Kontribusi
Kontribusi, laporan bug, dan permintaan fitur sangat kami hargai! ๐
Cara Berkontribusi
- Fork repositori ini
- Buat branch untuk fitur Anda (
git checkout -b feature/AmazingFeature) - Commit perubahan Anda (
git commit -m 'Add some AmazingFeature') - Push ke branch (
git push origin feature/AmazingFeature) - Buka Pull Request
Pengembangan Lokal
Untuk pengembangan lokal, kloning repositori dan instal dependensi:
git clone https://github.com/dzakwanalifi/stadata-x.git
cd stadata-x
pip install -e ".[dev]"
Jalankan aplikasi dalam mode pengembangan dengan hot-reloading:
textual run --dev stadata_x/main.py
Panduan Pengembangan
- Gunakan
ruffuntuk linting dan formatting - Ikuti konvensi penamaan PEP 8
- Tambahkan docstring untuk fungsi baru
- Update dokumentasi jika diperlukan
๐ Acknowledgments
- Badan Pusat Statistik (BPS) - Untuk menyediakan data publik yang berharga
- Textual - Framework TUI yang powerful
- stadata - Library Python resmi untuk API BPS
๐ Dukungan
Jika Anda mengalami masalah atau memiliki pertanyaan:
- ๐ง Email: dzakwan624@gmail.com
- ๐ Issues: GitHub Issues
- ๐ Dokumentasi: README ini
๐ Lisensi
Proyek ini dilisensikan di bawah Lisensi MIT - lihat file LICENSE untuk detail lebih lanjut.
Dibuat dengan โค๏ธ untuk komunitas data Indonesia
โญ Jika Anda menyukai proyek ini, berikan bintang di GitHub!
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 stadata_x-0.1.9.tar.gz.
File metadata
- Download URL: stadata_x-0.1.9.tar.gz
- Upload date:
- Size: 43.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9f95a63872e5a6e36e37595ee23473c7c7615aef4431d7fc5f697d019321ef6d
|
|
| MD5 |
0932fc1ec521eacf835544ae8043690d
|
|
| BLAKE2b-256 |
0eb762e0f7b77204af55d800ec9bef927d744f50e41b4163b052f7ae4ec349f1
|
File details
Details for the file stadata_x-0.1.9-py3-none-any.whl.
File metadata
- Download URL: stadata_x-0.1.9-py3-none-any.whl
- Upload date:
- Size: 31.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f2b10a5fee0b20c26df3af45581da089595dcaa66da57116692070fe2a127887
|
|
| MD5 |
cdd08213a70954868fe3370ae354f266
|
|
| BLAKE2b-256 |
55666450e6a50ebadcb12edeeff3a6c39efdc318cd7b2ef75da82379813f843b
|