Obliczanie rabatu cenowego według poziomu

Poziom umiejętności programowania: początkujący
Czas trwania: 10 minut
Typ projektu: Funkcja niestandardowa

Cele

  • Dowiedz się, na czym polega działanie rozwiązania.
  • Dowiedz się, jak usługi Apps Script działają w ramach rozwiązania.
  • Skonfiguruj skrypt.
  • Uruchom skrypt.

Informacje o rozwiązaniu

Jeśli oferujesz klientom system cen w wielu przedziałach, ta funkcja niestandardowa ułatwia obliczanie kwot rabatów dla Twoich cen.

Chociaż można użyć wbudowanej funkcji SUMPRODUCT do obliczenia cen według poziomów, korzystanie z funkcji SUMPRODUCT jest bardziej skomplikowane i mniej elastyczne niż korzystanie z funkcji niestandardowej w tym rozwiązaniu.

Zrzut ekranu z przykładem cen według poziomu

Jak to działa

Model cenowy oparty na poziomach oznacza, że koszt towarów lub usług maleje w zależności od ilości zakupionej usługi.

Załóżmy, że masz 2 poziomy: pierwszy w przedziale 0–500 zł ze zniżką 10%, a drugi w przedziale 501–1000 zł ze zniżką 20%. Jeśli łączna cena, dla której chcesz obliczyć rabat, wynosi 700 USD, skrypt pomnoży pierwsze 500 USD przez 10%, a pozostałe 200 USD przez 20%, co da łączny rabat w wysokości 90 USD.

W przypadku danej łącznej ceny skrypt przechodzi przez określone poziomy w tabeli cen poziomów. Każda część łącznej ceny, która mieści się w ramach poziomu, jest mnożona przez powiązaną z tym poziomem wartość procentową. Wynik to suma obliczeń dla każdego poziomu.

Usługi Apps Script

To rozwiązanie korzysta z tej usługi:

  • Usługa arkusza kalkulacyjnego – przyjmuje podany parametr i oblicza, jaką część tej wartości pomnożyć przez procent rabatu na każdym poziomie.

Wymagania wstępne

Aby skorzystać z tego szablonu, musisz spełnić te wymagania wstępne:

  • Konto Google (konta Google Workspace mogą wymagać zatwierdzenia przez administratora).
  • przeglądarka internetowa z dostępem do internetu;

Konfigurowanie skryptu

Kliknij przycisk poniżej, aby utworzyć kopię arkusza poziomów cenowych funkcji niestandardowej. Projekt Apps Script dla tego rozwiązania jest dołączony do arkusza kalkulacyjnego.
Utwórz kopię

Uruchamianie skryptu

  1. W skopiowanym arkuszu kalkulacja ceny w wierszu 16 pokazuje przykładową cenę produktu w modelu oprogramowania jako usługi (SaaS).
  2. Aby obliczyć kwotę rabatu, w komórce C20 wpisz =tierPrice(C19,$B$3:$D$6). Ostateczna cena jest aktualizowana w komórce C21. Jeśli znajdujesz się w miejscu, w którym używa się przecinków dziesiętnych, konieczne może być wpisanie wartości =tierPrice(C19;$B$3:$D$6).

Sprawdzanie kodu

Aby sprawdzić kod Apps Script dla tego rozwiązania, kliknij Wyświetl kod źródłowy poniżej:

Pokaż kod źródłowy

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;
}

Reguły przekształcania

Funkcję niestandardową możesz edytować według potrzeb. Poniżej znajdziesz opcjonalne informacje o ręcznym odświeżaniu wyników funkcji niestandardowych.

Odświeżanie wyników z pamięci podręcznej

W przeciwieństwie do funkcji wbudowanych funkcje niestandardowe są umieszczane w pamięci podręcznej Google w celu optymalizacji wydajności. Dlatego jeśli zmienisz coś w funkcji niestandardowej, np. wartość, która jest obliczana, może się okazać, że nie zostanie natychmiast wymuszone zaktualizowanie. Aby ręcznie odświeżyć wynik funkcji, wykonaj te czynności:

  1. Aby dodać pole wyboru do pustej komórki, kliknij Wstaw > Pole wyboru.
  2. Dodaj komórkę z polem wyboru jako dodatkowym parametrem funkcji niestandardowej. Jeśli na przykład dodasz pole wyboru do komórki D20, zaktualizuj funkcję tierPrice() w komórce C20 na =tierPrice(C19,$B$3:$D$6,D20).
  3. Zaznacz lub odznacz pole, aby odświeżyć wyniki funkcji niestandardowej.

Współtwórcy

Ten przykład jest obsługiwany przez Google przy pomocy ekspertów Google ds. programowania.

Dalsze kroki