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).
- 🎯 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.
- 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)
- ✅ 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
Pastikan Anda memiliki Python 3.9 atau yang lebih baru. stadata-x dapat diinstal dengan mudah menggunakan pip, pipx, atau uv.
pipx menginstal paket Python dalam lingkungan terisolasi, yang merupakan cara terbaik untuk menginstal aplikasi command-line.
pipx install stadata-xpip install stadata-xuv pip install stadata-xSetelah instalasi, verifikasi bahwa aplikasi terinstal dengan benar:
stadata-x --versionError: 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=allPenjelasan: stadata-x menggunakan lxml>=6.0.0 yang sudah include libxml2 binaries.
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
Error: PermissionError: [Errno 13] Permission denied
Solusi:
# Jalankan sebagai administrator atau gunakan virtual environment
python -m venv venv
venv\Scripts\activate
pip install stadata-xError: 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.orgError: 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# Install Miniconda atau Anaconda
# Buat environment baru
conda create -n stadata-env python=3.11
conda activate stadata-env
# Install package
pip install stadata-xpipx install stadata-x# 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# Untuk pip
pip install stadata-x -v
# Untuk uv
uv pip install stadata-x --verbose# 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)"ApiTokenError: Token API tidak diatur
Solusi:
- Jalankan
stadata-x - Tekan
suntuk Settings - Masukkan Token API BPS Anda
- Test koneksi dengan tombol "Tes Koneksi"
NoInternetError: Tidak ada koneksi internet
Solusi:
- Check koneksi internet
- Coba lagi dalam beberapa saat (rate limiting)
- Gunakan VPN jika diperlukan
# Clear cache
# Windows
rmdir /s %USERPROFILE%\.stadata-x
# Linux/Mac
rm -rf ~/.stadata-xJika 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: [email protected]
-
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
Untuk menggunakan aplikasi ini, Anda memerlukan Token API dari BPS. Token ini gratis dan berfungsi sebagai kunci untuk mengakses data.
- 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:
Jalankan aplikasi dari terminal Anda:
stadata-x| 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 |
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, laporan bug, dan permintaan fitur sangat kami hargai! 🎉
- 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
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- Gunakan
ruffuntuk linting dan formatting - Ikuti konvensi penamaan PEP 8
- Tambahkan docstring untuk fungsi baru
- Update dokumentasi jika diperlukan
- Badan Pusat Statistik (BPS) - Untuk menyediakan data publik yang berharga
- Textual - Framework TUI yang powerful
- stadata - Library Python resmi untuk API BPS
Jika Anda mengalami masalah atau memiliki pertanyaan:
- 📧 Email: [email protected]
- 🐛 Issues: GitHub Issues
- 📖 Dokumentasi: README ini
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!

