Katmanlı fiyat indirimi hesaplama

Kodlama seviyesi:
başlangıç düzeyi Süre: 10 dakika
Proje türü: Özel işlev

Hedefler

  • Çözümün ne işe yaradığını anlayın.
  • Apps Komut Dosyası hizmetlerinin çözümüne geçelim.
  • Komut dosyasını ayarlayın.
  • Komut dosyasını çalıştırın.

Bu çözüm hakkında

Müşterileriniz için katmanlı bir fiyatlandırma sistemi sunuyorsanız bu özel işlev, fiyatlarınız için indirim tutarlarını hesaplamayı kolaylaştırır.

Katmanlı fiyatlandırma oluşturmak için yerleşik SUMPRODUCT işlevini kullanabilirsiniz SUMPRODUCT kullanmak, bundan daha karmaşık ve daha az esnektir. işlevini kullanın.

Katman fiyatlandırma örneğinin ekran görüntüsü

İşleyiş şekli

Katmanlı fiyatlandırma modeli, mal veya hizmet maliyetinin düştüğünü gösterir. bir teklif tutarı seçin.

Örneğin, biri 0-500 ABD doları arasında değişen ve ve %20 oranında indirim uygulanmıştır. İndirimi hesaplamanız gereken toplam fiyat 700 TL ise komut dosyası çarpar ilk 500 TL'yi% 10, kalan 200 TL'yi ise %20 ile birer toplayarak toplam indirim tutarıdır. 90 ABD doları.

Belirli bir toplam fiyat için komut dosyası, katman fiyatlandırma tablosu. Toplam fiyatın her bir kısmı için bu kısım, katmanın ilişkili yüzdesiyle değer. Sonuç, her katmanın hesaplamasının toplamıdır.

Apps Komut Dosyası hizmetleri

Bu çözüm aşağıdaki hizmeti kullanır:

  • E-tablo hizmeti: Belirtilen değeri hesaplar ve her katmanın indirim yüzdesi.

Ön koşullar

Bu örneği kullanmak için aşağıdaki ön koşullara sahip olmanız gerekir:

  • Google Hesabı (Google Workspace hesapları (yönetici onayı gerektirir).
  • İnternete erişimi olan bir web tarayıcısı.

Komut dosyasını ayarlama

Katman fiyatlandırması özel işlevinin kopyasını oluşturmak için aşağıdaki düğmeyi tıklayın e-tablo kullanarak yapabilirsiniz. Şu kullanıcı için Apps Komut Dosyası projesi: bu çözüm e-tabloya eklenir.
Kopya oluştur

Komut dosyasını çalıştırma

  1. Kopyaladığınız e-tablonun 16. satırındaki tabloda örnek bir fiyat gösteriliyor hesaplamasına dahil edilmiştir.
  2. İndirim tutarını hesaplamak için C20 hücresine şu değeri girin: =tierPrice(C19,$B$3:$D$6). Son fiyat C21 hücresinde güncellenir. Eğer virgül kullanan bir konumda oturum açmak için Bunun yerine =tierPrice(C19;$B$3:$D$6).

Kodu inceleyin

Bu çözüm için Apps Komut Dosyası kodunu incelemek üzere Kaynak kodunu göster'i tıklayın aşağıda bulabilirsiniz:

Kaynak kodu göster

Code.gs

solutions/custom-functions/tier-pricing/Code.js
// To learn how to use this script, refer to the documentation:
// https://developers.google.com/apps-script/samples/custom-functions/tier-pricing

/*
Copyright 2022 Google LLC

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    https://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

/**
 * Calculates the tiered pricing discount.  
 *  
 * You must provide a value to calculate its discount. The value can be a string or a reference
 * to a cell that contains a string.
 * You must provide a data table range, for example, $B$4:$D$7, that includes the 
 * tier start, end, and percent columns. If your table has headers, don't include
 * the headers in the range.
 * 
 * @param {string} value The value to calculate the discount for, which can be a string or a 
 * reference to a cell that contains a string.
 * @param {string} table The tier table data range using A1 notation.
 * @return number The total discount amount for the value.
 * @customfunction
 *  
 */
function tierPrice(value, table) {
  let total = 0;
  // Creates an array for each row of the table and loops through each array.
  for (let [start, end, percent] of table) {
  // Checks if the value is less than the starting value of the tier. If it is less, the loop stops.
    if (value < start) {
      break;
    }
  // Calculates the portion of the value to be multiplied by the tier's percent value.
    let amount = Math.min(value, end) - start;
  // Multiplies the amount by the tier's percent value and adds the product to the total.
    total += amount * percent;
  }
  return total;
}

Değişiklikler

Özel işlevi, ihtiyaçlarınıza göre istediğiniz kadar düzenleyebilirsiniz. Şunun altında: özel işlev sonuçlarını manuel olarak yenilemek için kullanılan isteğe bağlı bir eklemedir.

Önbelleğe alınan sonuçları yenile

Google, yerleşik işlevlerin aksine, optimizasyon için özel bazı yolları da görmüştük. Bu nedenle, özel ayarlarınızda bir şeyi değiştirirseniz, işlevi kullanılarak (ör. hesaplanmakta olan bir değer) hemen güncellemeye zorlayın. İşlev sonucunu manuel olarak yenilemek için aşağıdaki komutu alın için şu adımları izleyin:

  1. Ekle'yi tıklayarak boş bir hücreye onay kutusu ekleme &gt; Onay kutusu'na dokunun.
  2. Onay kutusu içeren hücreyi, özel parametreye ait ekstra bir parametre olarak ekleyerek işlevini kullanın. Örneğin, D20 hücresine bir onay kutusu eklerseniz şu hücreyi güncelleyin: tierPrice() fonksiyonunu kullanarak C20 hücresindeki =tierPrice(C19,$B$3:$D$6,D20).
  3. Özel işlev sonuçlarını yenilemek için onay kutusunu işaretleyin veya kutunun işaretini kaldırın.

Katkıda bulunanlar

Bu örnek, Google Geliştirici Uzmanları'nın yardımıyla Google tarafından yönetilir.

Sonraki adımlar