Obliczanie rabatu cenowego według poziomu

Poziom kodowania: początkujący
Czas trwania: 10 minut
Typ projektu: Funkcja niestandardowa

Cele

  • Dowiedz się, do czego służy dane rozwiązanie.
  • dowiedzieć się, jak usługi Apps Script działają w danym rozwiązaniu.
  • Skonfiguruj skrypt.
  • Uruchom skrypt.

Informacje o rozwiązaniu

Jeśli oferujesz klientom zróżnicowany system cen, ta funkcja niestandardowa ułatwi Ci obliczenie wysokości rabatów dla Twoich cen.

Chociaż możesz użyć wbudowanej funkcji SUMPRODUCT, aby dokonać wielopoziomowych obliczeń cenowych, użycie SUMPRODUCT jest bardziej złożone i mniej elastyczne niż funkcja niestandardowa tego rozwiązania.

Zrzut ekranu przedstawiający przykładowe ceny poszczególnych poziomów

Jak to działa

Wariantowy model cenowy oznacza, że koszt towarów lub usług obniża się w zależności od zakupionej ilości.

Załóżmy na przykład, że masz 2 poziomy: od 0 do 500 zł i ze zniżką 10%, a drugi z rabatem w wysokości 20%: 501–1000 zł. Jeśli łączna cena, dla której należy obliczyć rabat, to 700 zł, skrypt mnoży pierwsze 500 zł przez 10%, a pozostałe 200 zł przez 20%, co daje łączny rabat w wysokości 90 zł.

W przypadku danej ceny łącznej skrypt sprawdza poziomy określone w tabeli z cenami. Każda część łącznej ceny zawartej w danym poziomie jest mnożona przez powiązaną wartość procentową. Wynik to suma obliczeń dla każdego poziomu.

Usługi Apps Script

To rozwiązanie korzysta z następującej usługi:

  • Usługa arkusza kalkulacyjnego – pobiera podaną wartość i oblicza, jaką część wartości należy pomnożyć przez rabat procentowy każdego poziomu.

Wymagania wstępne

Aby korzystać z tego przykładu, musisz spełnić te wymagania wstępne:

  • konta Google (konta Google Workspace mogą wymagać zatwierdzenia przez administratora),
  • Przeglądarka z dostępem do internetu.

Konfigurowanie skryptu

Kliknij przycisk poniżej, aby utworzyć kopię arkusza kalkulacyjnego Niestandardowa funkcja cennika. Projekt Apps Script dla tego rozwiązania jest dołączony do arkusza kalkulacyjnego.
Utwórz kopię

Uruchom skrypt

  1. W kopiowanym arkuszu kalkulacyjnym tabela w wierszu 16 zawiera przykładową wycenę usługi „oprogramowanie jako usługa” (SaaS).
  2. Aby obliczyć kwotę rabatu, w komórce C20 wpisz =tierPrice(C19,$B$3:$D$6). Ostateczna cena zostaje zaktualizowana w komórce C21. Jeśli w Twojej lokalizacji występują przecinki dziesiętne, być może musisz wpisać =tierPrice(C19;$B$3:$D$6).

Sprawdź kod

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

Modyfikacje

Funkcję niestandardową możesz edytować tak długo, jak chcesz. Poniżej znajduje się opcjonalny dodatek umożliwiający ręczne odświeżenie wyników funkcji niestandardowej.

Odśwież wyniki w pamięci podręcznej

W przeciwieństwie do funkcji wbudowanych Google zapisuje w pamięci podręcznej funkcje niestandardowe, aby zoptymalizować wydajność. Jeśli więc zmienisz coś w funkcji niestandardowej, na przykład obliczaną wartość, aktualizacja może nie zostać od razu wymuszona. Aby ręcznie odświeżyć wynik funkcji:

  1. Dodaj pole wyboru do pustej komórki, klikając Wstaw > Pole wyboru.
  2. Dodaj komórkę z polem wyboru jako dodatkowy parametr funkcji niestandardowej. Jeśli na przykład dodasz pole wyboru do komórki D20, zmień wartość funkcji tierPrice() w komórce C20 na =tierPrice(C19,$B$3:$D$6,D20).
  3. Zaznacz lub odznacz pole wyboru, aby odświeżyć wyniki funkcji niestandardowej.

Współtwórcy

Ta próbka jest opracowywana przez Google z pomocą Ekspertów Produktowych Google.

Dalsze kroki