Tingkat coding: Pemula
Durasi: 10 menit
Jenis project: Fungsi kustom
Tujuan
- Pahami fungsi solusi.
- Pahami fungsi layanan Apps Script dalam solusi.
- Siapkan skrip.
- Jalankan skrip.
Tentang solusi ini
Jika Anda menawarkan sistem harga bertingkat untuk pelanggan, fungsi kustom ini akan mempermudah perhitungan jumlah diskon untuk harga Anda.
Meskipun Anda dapat menggunakan fungsi bawaan SUMPRODUCT
untuk membuat perhitungan harga bertingkat, penggunaan SUMPRODUCT
lebih rumit dan kurang fleksibel dibandingkan fungsi kustom solusi ini.
Cara kerjanya
Model harga bertingkat berarti biaya barang atau jasa akan turun berdasarkan jumlah yang dibeli.
Misalnya, bayangkan Anda memiliki dua tingkat, satu yang memiliki rentang $0-$500 dan didiskon 10%, dan satu lagi yang memiliki rentang $501-$1.000 dan didiskon 20%. Jika total harga yang perlu Anda hitung diskonnya adalah $700, skrip mengalikan 500 USD pertama dengan 10% dan 200 USD sisanya dengan 20%, sehingga total diskonnya adalah 90 USD.
Untuk harga total tertentu, skrip melakukan perulangan melalui tingkat yang ditentukan dalam tabel harga bertingkat. Untuk setiap bagian dari total harga yang termasuk dalam tingkat, bagian tersebut dikalikan dengan nilai persentase yang terkait dengan tingkat tersebut. Hasilnya adalah jumlah penghitungan setiap tingkat.
Layanan Apps Script
Solusi ini menggunakan layanan berikut:
- Layanan spreadsheet–Mengambil nilai yang diberikan dan menghitung bagian nilai yang akan dikalikan dengan diskon persentase setiap tingkat.
Prasyarat
Untuk menggunakan sampel ini, Anda memerlukan prasyarat berikut:
- Akun Google (akun Google Workspace mungkin memerlukan persetujuan administrator).
- Browser web dengan akses ke internet.
Menyiapkan skrip
Klik tombol di bawah untuk membuat salinan spreadsheet Fungsi kustom harga berjenjang. Project Apps Script untuk
solusi ini dilampirkan ke spreadsheet.
Buat salinan
Jalankan skrip:
- Di spreadsheet yang Anda salin, tabel di baris 16 menampilkan contoh perhitungan harga untuk produk Software as a Service (SaaS).
- Untuk menghitung jumlah diskon, di sel
C20
, masukkan=tierPrice(C19,$B$3:$D$6)
. Harga akhir diperbarui di selC21
. Jika Anda berada di lokasi yang menggunakan koma desimal, Anda mungkin perlu memasukkan=tierPrice(C19;$B$3:$D$6)
sebagai gantinya.
Meninjau kode
Untuk meninjau kode Apps Script untuk solusi ini, klik Lihat kode sumber di bawah:
Melihat kode sumber
Code.gs
Modifikasi
Anda dapat mengedit fungsi kustom sesering yang Anda inginkan agar sesuai dengan kebutuhan Anda. Di bawah ini adalah tambahan opsional untuk memuat ulang hasil fungsi kustom secara manual.
Memperbarui hasil yang di-cache
Tidak seperti fungsi bawaan, Google menyimpan fungsi kustom dalam cache untuk mengoptimalkan performa. Oleh karena itu, jika Anda mengubah sesuatu dalam fungsi kustom, seperti nilai yang sedang dihitung, perubahan tersebut mungkin tidak langsung memicu update. Untuk memuat ulang hasil fungsi secara manual, lakukan langkah-langkah berikut:
- Tambahkan kotak centang ke sel kosong dengan mengklik Sisipkan > Kotak centang.
- Tambahkan sel yang memiliki kotak centang sebagai parameter tambahan fungsi kustom. Misalnya, jika Anda menambahkan kotak centang ke sel
D20
, perbarui fungsitierPrice()
di selC20
menjadi=tierPrice(C19,$B$3:$D$6,D20)
. - Centang atau hapus centang pada kotak centang untuk memuat ulang hasil fungsi kustom.
Kontributor
Contoh ini dikelola oleh Google dengan bantuan Pakar Developer Google.