רמת קידוד: מתחילים
משך: 10 דקות
סוג הפרויקט: פונקציה מותאמת אישית
מטרות
- להבין מה הפתרון עושה.
- הסבר על הפעולות של שירותי Apps Script בתוך הפתרון.
- מגדירים את הסקריפט.
- מריצים את הסקריפט.
מידע על הפתרון הזה
אם אתם מציעים ללקוחות מערכת תמחור עם רמות שונות, הפונקציה המותאמת אישית הזו מאפשרת לכם לחשב בקלות את סכומי ההנחות על המחירים.
אפשר להשתמש בפונקציה המובנית SUMPRODUCT
כדי לבצע חישוב של תמחור מדורג, אבל השימוש ב-SUMPRODUCT
מורכב יותר ופחות גמיש בהשוואה לפונקציה בהתאמה אישית של הפתרון הזה.
איך זה עובד
מודל תמחור מדורג מאפשר לכם ליהנות מהנחות על מוצרים או שירותים בהתאם לכמות שאתם רוכשים.
לדוגמה, נניח שיש לכם שתי רמות, אחת בטווח 0-500$ עם הנחה של 10%, ואחת בטווח 501-1,000$ עם הנחה של 20%. אם המחיר הכולל שצריך לחשב לו הנחה הוא 700$, התסריט מחשב את ההנחה על ידי הכפלת 500 $הראשונים ב-10% והכפלת 200 $הנותרים ב-20%, כך שההנחה הכוללת היא 90$.
עבור מחיר כולל נתון, הסקריפט עובר בחזרה על כל הרמות שצוינו בטבלת התמחור לפי רמה. כל חלק מהמחיר הכולל שנכלל ברמה מסוימת מוכפל בערך האחוז המשויך לרמה. התוצאה היא הסכום של כל חישוב של רמה.
שירותי Apps Script
הפתרון הזה משתמש בשירות הבא:
- שירות גיליון אלקטרוני – הפונקציה מקבלת את הערך הנתון ומחשבת איזה חלק מהערך צריך להכפיל בשיעור ההנחה באחוזים של כל רמה.
דרישות מוקדמות
כדי להשתמש בדוגמה הזו, צריך את הדרישות המוקדמות הבאות:
- חשבון Google (יכול להיות שחשבונות Google Workspace ידרשו אישור אדמין).
- דפדפן אינטרנט עם גישה לאינטרנט.
הגדרת הסקריפט
לוחצים על הלחצן שבהמשך כדי ליצור עותק של הגיליון האלקטרוני פונקציה מותאמת אישית של תמחור לפי רמות. פרויקט Apps Script של הפתרון הזה מצורף לגיליון האלקטרוני.
יצירת עותק
מריצים את הסקריפט
- בגיליון האלקטרוני שהעתקתם, בטבלה בשורה 16 מוצג חישוב מחיר לדוגמה של מוצר תוכנה כשירות (SaaS).
- כדי לחשב את סכום ההנחה, מזינים
=tierPrice(C19,$B$3:$D$6)
בתאC20
. המחיר הסופי מתעדכן בתאC21
. אם אתם נמצאים במיקום שבו נעשה שימוש בפסיק עשרוני, יכול להיות שתצטרכו להזין את הערך=tierPrice(C19;$B$3:$D$6)
במקום זאת.
בדיקת הקוד
כדי לבדוק את הקוד של Apps Script לפתרון הזה, לוחצים על הצגת קוד המקור למטה:
הצגת קוד המקור
Code.gs
שינויים
אתם יכולים לערוך את הפונקציה בהתאם לצרכים שלכם. בהמשך מופיעה תוספת אופציונלית לרענון ידני של תוצאות של פונקציות בהתאמה אישית.
רענון תוצאות שנשמרו במטמון
בניגוד לפונקציות מובנות, Google שומרת פונקציות בהתאמה אישית במטמון כדי לבצע אופטימיזציה של הביצועים. לכן, אם משנים משהו בפונקציה בהתאמה אישית, כמו ערך שמחושב, יכול להיות שהעדכון לא יתבצע באופן מיידי. כדי לרענן את תוצאת הפונקציה באופן ידני, מבצעים את השלבים הבאים:
- כדי להוסיף תיבת סימון לתא ריק, לוחצים על הוספה > תיבת סימון.
- מוסיפים את התא עם תיבת הסימון כפרמטר נוסף של הפונקציה בהתאמה אישית. לדוגמה, אם מוסיפים תיבת סימון לתא
D20
, צריך לעדכן את הפונקציהtierPrice()
בתאC20
ל-=tierPrice(C19,$B$3:$D$6,D20)
. - מסמנים או מבטלים את הסימון של תיבת הסימון כדי לרענן את התוצאות של הפונקציה בהתאמה אישית.
תורמים
Google שומרת על הדוגמה הזו בעזרת מומחי הפיתוח של Google.