חישוב של הנחה על תמחור לפי רמות

רמת תכנות: מתחיל
משך: 10 דקות
סוג פרויקט: פונקציה מותאמת אישית

מטרות

  • הבנה מה הפתרון עושה.
  • להבין מה שירותי Apps Script עושים במסגרת הפתרון.
  • מגדירים את הסקריפט.
  • מריצים את הסקריפט.

מידע על הפתרון הזה

אם אתם מציעים ללקוחות מערכת תמחור מדורגת, הפונקציה המותאמת אישית הזו מאפשרת לחשב בקלות את סכומי ההנחה במחירים.

אפשר להשתמש בפונקציה המובנית SUMPRODUCT כדי לבצע חישוב תמחור לפי רמות, אבל השימוש בפונקציה SUMPRODUCT הוא מורכב יותר ופחות גמיש מהפונקציה המותאמת אישית של הפתרון הזה.

צילום מסך של דוגמת התמחור של רמה

איך זה עובד

מודל תמחור מדורג פירושו שעלות המוצרים או השירותים יורדת בהתאם לכמות שנרכשה.

לדוגמה, נניח שיש לכם שתי רמות: אחת עם מחיר שנעים בין 0 $ל-500$, עם הנחה של 10% ואחת עם מחירים שנעים בין 501 $ל-1,000$, עם הנחה של 20%. במקרה שהמחיר הכולל לחישוב הנחה הוא 700$, הסקריפט יכפיל את ה-500 $הראשונים ב-10% ואת היתרה של 200 $ב-20%, כך שההנחה הכוללת תהיה 90$.

במחיר כולל נתון, הסקריפט עובר דרך הרמות שצוינו בטבלת התמחור של הרמות. לכל חלק מהמחיר הכולל שנמצא בתוך רמה, החלק הזה מוכפל בערך האחוז שמשויך לרמה. התוצאה היא סכום החישוב של כל שכבה.

שירותי Apps Script

בפתרון הזה נעשה שימוש בשירות הבא:

  • גיליון אלקטרוני – הפונקציה הזו לוקחת את הערך הנתון ומחשבת את החלק מהערך להכפלה של אחוז ההנחה בכל רמה.

דרישות מוקדמות

כדי להשתמש בדוגמה הזו, נדרשות הדרישות המוקדמות הבאות:

  • חשבון Google (יכול להיות שיהיה צורך באישור אדמין).
  • דפדפן אינטרנט עם גישה לאינטרנט.

הגדרת הסקריפט

לחצו על הלחצן שלמטה כדי ליצור עותק של הגיליון האלקטרוני Tier pricing custom function. פרויקט Apps Script לפתרון הזה מצורף לגיליון האלקטרוני.
יצירת עותק

מריצים את הסקריפט

  1. בגיליון האלקטרוני שהעתקתם, בטבלה בשורה 16 מוצג חישוב מחיר לדוגמה של מוצר מסוג 'תוכנה כשירות' (SaaS).
  2. כדי לחשב את סכום ההנחה, מזינים =tierPrice(C19,$B$3:$D$6) בתא C20. המחיר הסופי יתעדכן בתא C21. אם אתם נמצאים במקום שבו משתמשים בפסיקים, יכול להיות שתצטרכו להזין =tierPrice(C19;$B$3:$D$6) במקום זאת.

בדיקת הקוד

כדי לבדוק את קוד Apps Script של הפתרון הזה, לוחצים על הצגת קוד מקור למטה:

הצגת קוד המקור

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

שינויים

אפשר לערוך את הפונקציה המותאמת אישית כמה פעמים שרוצים. בהמשך מופיעה תוספת אופציונלית לרענון ידני של תוצאות של פונקציות מותאמות אישית.

רענון של התוצאות שנשמרו במטמון

בניגוד לפונקציות מובנות, Google שומרת פונקציות בהתאמה אישית במטמון כדי לשפר את הביצועים. לכן, אם מבצעים שינוי בפונקציה בהתאמה אישית, למשל ערך שמחושב, יכול להיות שלא יתבצע עדכון מיידי. כדי לרענן את התוצאה של הפונקציה באופן ידני:

  1. כדי להוסיף תיבת סימון לתא ריק, לוחצים על הוספה > תיבת סימון.
  2. מוסיפים את התא עם תיבת הסימון כפרמטר נוסף של הפונקציה בהתאמה אישית. לדוגמה, אם מוסיפים תיבת סימון לתא D20, צריך לעדכן את הפונקציה tierPrice() בתא C20 לערך =tierPrice(C19,$B$3:$D$6,D20).
  3. כדי לרענן את התוצאות של הפונקציות המותאמות אישית, מסמנים את התיבה או מבטלים את הסימון שלה.

תורמים

הדוגמה הזו מנוהלת על ידי Google בעזרת מומחי המפתחים של Google.

השלבים הבאים