Abgestuften Preisrabatt berechnen

Programmierkenntnisse: Anfänger
Dauer: 10 Minuten
Projekttyp: Benutzerdefinierte Funktion

Ziele

  • Verstehen, was die Lösung bewirkt
  • Verstehen, was die Google Apps Script-Dienste in der Lösung bewirken
  • Das Script einrichten
  • Das Script ausführen.

Informationen zu dieser Lösung

Wenn Sie Ihren Kunden ein gestaffeltes Preissystem anbieten, können Sie mit dieser benutzerdefinierten Funktion die Rabattbeträge für Ihre Preise in Google Sheets einfacher berechnen.

Sie können zwar die integrierte Funktion SUMPRODUCT verwenden, um eine gestaffelte Preisberechnung durchzuführen, aber die Verwendung von SUMPRODUCT ist komplexer und weniger flexibel als die benutzerdefinierte Funktion dieser Lösung.

Google-Tabelle mit einer Berechnung für gestaffelte Preise

Funktionsweise

Bei einem gestaffelten Preissystem sinken die Kosten für Waren oder Dienstleistungen je nach gekaufter Menge.

Angenommen, Sie haben zwei Stufen: eine von 0 bis 500 $ mit einem Rabatt von 10% und eine von 501 bis 1.000 $ mit einem Rabatt von 20%. Wenn der Gesamtpreis, für den Sie einen Rabatt berechnen müssen, 700 $beträgt, multipliziert das Script die ersten 500 $mit 10% und die restlichen 200 $mit 20%, was einem Gesamtrabatt von 90 $entspricht.

Bei einem bestimmten Gesamtpreis durchläuft das Script die angegebenen Stufen in der Tabelle mit den gestaffelten Preisen. Für jeden Teil des Gesamtpreises, der in eine Stufe fällt, wird dieser Teil mit dem zugehörigen Prozentsatz der Stufe multipliziert. Das Ergebnis ist die Summe der Berechnungen für jede Stufe.

Apps Script-Dienste

Diese Lösung verwendet den folgenden Dienst:

  • Tabellendienst: Nimmt den angegebenen Wert und berechnet, welcher Teil des Werts mit dem prozentualen Rabatt jeder Stufe multipliziert werden muss.

Vorbereitung

Für die Verwendung dieses Beispiels sind folgende Voraussetzungen erforderlich:

  • Ein Google-Konto (für Google Workspace-Konten ist möglicherweise die Genehmigung durch den Administrator erforderlich)
  • Ein Webbrowser mit Internetzugriff

Script einrichten

Klicken Sie auf die folgende Schaltfläche, um eine Kopie der Tabelle Benutzerdefinierte Funktion für gestaffelte Preise zu erstellen:

Kopie erstellen

Das Apps Script-Projekt für diese Lösung ist an die Tabelle angehängt.

Das Script ausführen

  1. In der kopierten Tabelle zeigt die Tabelle in Zeile 16 eine Beispielpreisberechnung für ein SaaS-Produkt (Software as a Service).
  2. Geben Sie in Zelle C20 =tierPrice(C19,$B$3:$D$6) ein, um den Rabattbetrag zu berechnen. Der Endpreis wird in Zelle C21 aktualisiert. Wenn Sie sich an einem Ort befinden, an dem Kommas als Dezimaltrennzeichen verwendet werden, müssen Sie möglicherweise stattdessen =tierPrice(C19;$B$3:$D$6) eingeben.

Code ansehen

Klicken Sie auf Quellcode ansehen, um den Apps Script-Code für diese Lösung zu sehen:

Quellcode ansehen

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 (const [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.
    const 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;
}

Änderungen

Sie können die benutzerdefinierte Funktion nach Bedarf bearbeiten. Wenn Sie eine optionale Ergänzung zum manuellen Aktualisieren der Ergebnisse benutzerdefinierter Funktionen sehen möchten, klicken Sie auf Im Cache gespeicherte Ergebnisse aktualisieren:

Im Cache gespeicherte Ergebnisse aktualisieren

Im Gegensatz zu integrierten Funktionen werden benutzerdefinierte Funktionen von Google im Cache gespeichert, um die Leistung zu optimieren. Wenn Sie also etwas in Ihrer benutzerdefinierten Funktion ändern, z. B. einen Wert, der berechnet wird, wird möglicherweise nicht sofort eine Aktualisierung erzwungen. So aktualisieren Sie das Ergebnis der Funktion manuell:

  1. Fügen Sie einer leeren Zelle ein Kästchen hinzu, indem Sie auf Einfügen > Kästchen klicken.
  2. Fügen Sie die Zelle mit dem Kästchen als zusätzlichen Parameter der benutzerdefinierten Funktion hinzu. Wenn Sie beispielsweise der Zelle D20 ein Kästchen hinzufügen, aktualisieren Sie die tierPrice() Funktion in Zelle C20 zu =tierPrice(C19,$B$3:$D$6,D20).
  3. Setzen Sie ein Häkchen in das Kästchen oder entfernen Sie es, um die Ergebnisse der benutzerdefinierten Funktion zu aktualisieren.

Beitragende

Dieses Beispiel wird von Google mit Unterstützung von Google Developer Experts verwaltet.

Nächste Schritte