PyProc (Python Procurement) merupakan wrapper untuk API SPSE Versi 4 yang ditulis dalam bahasa Python. Sistem Pengadaan Secara Elektronik (SPSE) SPSE merupakan aplikasi e-Procurement yang dikembangkan oleh LKPP untuk digunakan oleh LPSE di instansi pemerintah seluruh Indonesia.
DISCLAIMER:
Penulis tidak terafiliasi dengan pengembang SPSE atau pemilik aplikasi SPSE. Software ini dikembangkan dengan tujuan akademis, bentuk pengawasan oleh masyarakat, dan membantu pengusaha untuk mempermudah otomasi perolehan informasi pengadaan dari pemerintah.
Penggunaan yang tidak wajar dan mengganggu sebagian atau seluruh fungsi aplikasi SPSE pada satuan kerja menjadi tanggung jawab masing-masing pengguna.
PyProc ada karena SPSE ada, jadi gunakanlah dengan bijak dan secukupnya.
Pemasangan PyProc via pip
:
$ pip install pyproc
Upgrade PyProc via pip
:
$ pip install pyproc --upgrade
Instalasi versi unstable:
$ pip install git+https://github.com/wakataw/pyproc.git
atau, Download executeable file (.exe) untuk windows di sini (experimental).
Anda bisa menjalankan beberapa Test Case untuk memastikan semua fungsi berjalan dengan baik. Clone repository ini lalu jalankan perintah berikut:
$ git clone https://github.com/wakataw/pyproc.git
$ cd pyproc
$ python setup.py test
Format Command
$ pyproc [ARGUMENT] DAFTAR_LPSE
Arguments
argumen | contoh | diperlukan | default | keterangan |
---|---|---|---|---|
DAFTAR_LPSE |
pyproc http://lpse.pu.go.id |
Ya | - | Daftar alamat LPSE yang akan diunduh. Format Daftar LPSE |
-h --help |
pyproc --help |
optional | - | menampilkan keterangan dan bantuan |
-k --keyword |
pyproc --keyword "mobil dinas" ... |
optional | - | filter pencarian index paket berdasarkan kata kunci tertentu |
-t --tahun-anggaran |
pyproc --tahun-anggaran 2021 ... |
optional | Tahun Berjalan | Filter pencarian index paket berdasarkan tahun anggaran tertentu. Fungsi ini hanya berlaku mulai dari SPSE 4.4. Format Penulisan: ALL: mengunduh seluruh data 2021: mengunduh data untuk tahun 2021 2015,2018,2019: mengunduh data untuk tahun 2015, 2018, dan 2019 2011-2020 mengunduh data untuk tahun 2011 s.d. 2020 |
--kategori |
pyproc --kategori PENGADAAN_BARANG ... |
optional | - | Filter pencarian berdasarkan kategori pengadaan. Daftar kategori: PENGADAAN_BARANG , JASA_KONSULTANSI_BADAN_USAHA_NON_KONSTRUKSI , PEKERJAAN_KONSTRUKSI , JASA_LAINNYA , JASA_KONSULTANSI_PERORANGAN , JASA_KONSULTANSI_BADAN_USAHA_KONSTRUKSI |
--nama-penyedia |
pyproc --nama-penyedia "PT SUKA MAJU" ... |
optional | - | Filter pencarian index paket berdasarkan nama penyedia |
-c --chunk-size |
pyproc --chunk-size 25 ... |
optional | 25 | Jumlah daftar paket per halaman yang diunduh. Semakin besar jumlah tidak menjamin proses download semakin cepat. Gunakanlah jumlah data yang wajar sehingga tidak membebani server SPSE. |
-w --workers |
pyproc --workers 4 ... |
optional | 8 | Jumlah koneksi yang berjalan secara bersamaan saat mengunduh detil paket dengan maksimal 10 worker. |
-x --timeout |
pyproc --timeout 60 ... |
optional | 30 | Waktu tunggu jika koneksi lambat (dalam detik) |
-n --non-tender |
pyproc --non-tender ... |
optional | FALSE | Tambahkan argumen ini untuk mengunduh data non-tender/pengadaan langsung |
-d --index-download-delay |
pyproc --index-download-delay 5 ... |
optional | 1 | Waktu jeda download index paket untuk setiap halaman/batch |
-o --output |
pyproc --ouput csv ... |
optional | csv | Jenis data keluaran/hasil dari download. Format yang didukung csv dan json. Karena keterbatasan format, tidak semua data ditampilkan pada format csv. Jika memerlukan data detil yang komprehensif, gunakan format json karena mencangkup semua data detail. |
--keep-index |
pyproc --keep-index ... |
optinal | FALSE | pyproc akan membentuk file idx (sqlite3 database) saat proses download dan akan dihapus ketika proses selesai. Tambahkan argumen ini jika tidak ingin menghapus database tersebut. |
-r --resume |
pyproc --resume ... |
optinal | FALSE | Tambahkan argument ini untuk melanjutkan proses yang gagal (karena internet putus atau gangguan koneksi lainnya). Namun pastikan bahwa seluruh index sudah berhasil diunduh karena argumen --resume akan melewati proses download index. |
-s --sep |
pyproc --sep ";" https://lpse.com |
optional | ; titik koma |
Set custom separator untuk output format csv |
--log |
pyproc --log INFO ... |
optional | INFO | Argumen untuk setting informasi yang ditampilkan pyproc pada terminal. Daftar nilai yang didukung: DEBUG : menampilkan informasi sedetil mungkinINFO : menampilkan informasi penting saja WARNING : hanya menampilkan informasi yang bersifat warning ERROR : hanya menampilkan error CRITICAL : hanya menampilkan permasalahan yang bersifat kritis saja |
PyProc dapat mengunduh data dari 1 atau lebih LPSE. Proses tersebut akan berjalan sesuai dengan nilai DAFTAR_LPSE
yang diberikan user. Beberapa format yang didukung oleh PyProc adalah sebagai berikut:
-
Download data dengan menyertakan nama file hasil download
Untuk set nama file secara manual, gunakan format
"alamatlpse[titik_koma]namafile"
.$ pyproc "http://lpse.pu.go.id;namaoutput" --output json
perintah ini akan mengunduh data LPSE PU dan mengekspor data ke file
namaoutput.json
-
Download data lebih dari 1 LPSE
Untuk mengunduh lebih dari 1 lpse secara bersamaan, gunakan format
"alamat1[koma]alamat2[koma]alamat3"
$ pyproc https://lpse.jakarta.go.id,http://lpse.pu.go.id
atau dengan menyertakan namafile dengan format
"alamat1[titikkoma]nama1[koma]alamat2[titikkoma]nama2"
$ pyproc "https://lpse.jakarta.go.id;filejakarta,http://lpse.pu.go.id;filepu"
- Download data berdasrakan daftar lpse pada file csv Download paket LPSE dengan sumber alamat dari file
$ pyproc daftarlpse.csv # konten daftarlpse.csv lpse.sumbarprov.go.id lpse.pu.go.id lpse.kemenkeu.go.id # konten daftarlpse.csv dengan nama hasil download lpse.sumbarprov.go.id;lpse-sumbar lpse.pu.go.id;lpse-pu.csv lpse.kemenkeu.go.id;lpse-kemenkeu
Untuk mengunduh daftar alamat LPSE berdasarkan situs inaproc (https://inaproc.id/lpse), jalankan perintah berikut:
$ pyproc daftarlpse
Perintah tersebut akan mengunduh daftar alamat lpse dan mengekspornya ke file daftarlpse.csv
.
Untuk dapat menggunakan PyProc, anda harus mengimpornya terlebih dahulu dan menginisiasi objek Lpse
from pyproc import Lpse
# Inisiasi objek lpse kementerian pu
lpse = Lpse('http://lpse.pu.go.id')
# Print versi dan last update aplikasi SPSE
print(lpse.version)
print(lpse.last_update)
from pyproc import Lpse
lpse = Lpse('http://lpse.pu.go.id')
# mendapatkan daftar paket lelang
daftar_lelang = lpse.get_paket_tender(start=0, length=2)
print(daftar_lelang)
# pencarian paket non tender (penunjukkan langsung)
daftar_pl = lpse.get_paket_non_tender(start=0, length=30)
Pencarian Paket dengan mengurutkan berdasarkan kolom tertentu
from pyproc import Lpse
from pyproc.lpse import By
lpse = Lpse('http://lpse.padang.go.id')
# pencarian daftar lelang, urutkan berdasarkan Harga Perkiraan Sendiri
daftar_lelang = lpse.get_paket_tender(start=0, length=30, order=By.HPS)
Filter pencarian paket berdasarkan kategori pengadaan
from pyproc import Lpse
from pyproc import JenisPengadaan
lpse = Lpse('http://lpse.padang.go.id')
# Kategori Pengadaan Barang
paket_pengadaan_barang = lpse.get_paket_tender(start=0, length=30, kategori=JenisPengadaan.PENGADAAN_BARANG)
paket_konstruksi = lpse.get_paket_tender(start=0, length=30, kategori=JenisPengadaan.PEKERJAAN_KONSTRUKSI)
# dst untuk kategori lainnya
from pyproc import Lpse
lpse = Lpse('http://lpse.padang.go.id')
# mendapatkan semua detil paket lelang
detil = lpse.detil_paket_tender(id_paket='48658064')
detil.get_all_detil()
print(detil)
# mendapatkan hanya pemenang lelang
pemenang = detil.get_pemenang()
print(pemenang)
Untuk uninstall package jalankan perintah berikut:
$ pip uninstall pyproc
Paket ini di-release di bawah lisensi MIT.
Orang-orang yang berjasa menyediakan kopi sehingga pengembangan paket tetap berjalan
- Angga Rinaldi Rizal (50 cangkir ☕️)