Calcula un descuento de precios por niveles

Nivel de programación: Principiante
Duración: 10 minutos
Tipo de proyecto: Función personalizada

Objetivos

  • Comprender qué hace la solución
  • Comprender qué hacen los servicios de Apps Script dentro de la solución
  • Configura la secuencia de comandos.
  • Ejecuta la secuencia de comandos.

Acerca de esta solución

Si ofreces un sistema de precios por niveles a tus clientes, esta función personalizada te ayudará a calcular los importes de descuento de tus precios con mayor facilidad.

Si bien puedes usar la función integrada SUMPRODUCT para realizar un cálculo de precios por niveles, usar SUMPRODUCT es más complejo y menos flexible que la función personalizada de esta solución.

Captura de pantalla del ejemplo de precios por nivel

Cómo funciona

Un modelo de precios por niveles significa que el costo de los bienes o servicios disminuye según la cantidad que se compra.

Por ejemplo, imagina que tienes dos niveles: uno que va de USD 0 a USD 500 y tiene un descuento del 10%, y otro que va de USD 501 a USD 1,000 y tiene un descuento del 20%. Si el precio total para el que necesitas calcular un descuento es de USD 700, la secuencia de comandos умножает los primeros USD 500 por el 10% y los USD 200 restantes por el 20%, para un descuento total de USD 90.

Para un precio total determinado, la secuencia de comandos realiza un bucle por los niveles especificados en la tabla de precios de niveles. Para cada parte del precio total que se encuentra dentro de un nivel, esa parte se multiplica por el valor porcentual asociado del nivel. El resultado es la suma del cálculo de cada nivel.

Servicios de Apps Script

En esta solución, se usa el siguiente servicio:

  • Servicio de hoja de cálculo: Toma el valor determinado y calcula qué parte del valor se debe multiplicar por el porcentaje de descuento de cada nivel.

Requisitos previos

Para usar esta muestra, debes cumplir con los siguientes requisitos previos:

  • Una Cuenta de Google (es posible que las cuentas de Google Workspace requieran aprobación del administrador)
  • Un navegador web con acceso a Internet

Configura la secuencia de comandos

Haz clic en el siguiente botón para crear una copia de la hoja de cálculo de la función personalizada de precios por nivel. El proyecto de Apps Script para esta solución está adjunto a la hoja de cálculo.
Crear una copia

Ejecuta la secuencia de comandos:

  1. En la hoja de cálculo copiada, la tabla de la fila 16 muestra un cálculo de precio de ejemplo para un producto de software como servicio (SaaS).
  2. Para calcular el importe del descuento, en la celda C20, ingresa =tierPrice(C19,$B$3:$D$6). El precio final se actualiza en la celda C21. Si te encuentras en una ubicación que usa comas decimales, es posible que debas ingresar =tierPrice(C19;$B$3:$D$6).

Revisa el código

Para revisar el código de Apps Script de esta solución, haz clic en Ver código fuente a continuación:

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

Modificaciones

Puedes editar la función personalizada tanto como quieras para que se adapte a tus necesidades. A continuación, se incluye una adición opcional para actualizar manualmente los resultados de las funciones personalizadas.

A diferencia de las funciones integradas, Google almacena en caché las funciones personalizadas para optimizar el rendimiento. Por lo tanto, si cambias algo dentro de tu función personalizada, como un valor que se está calculando, es posible que no se forje una actualización de inmediato. Para actualizar el resultado de la función de forma manual, sigue estos pasos:

  1. Para agregar una casilla de verificación a una celda vacía, haz clic en Insertar > Casilla de verificación.
  2. Agrega la celda que tiene la casilla de verificación como un parámetro adicional de la función personalizada. Por ejemplo, si agregas una casilla de verificación a la celda D20, actualiza la función tierPrice() en la celda C20 a =tierPrice(C19,$B$3:$D$6,D20).
  3. Marca o desmarca la casilla de verificación para actualizar los resultados de la función personalizada.

Colaboradores

Google mantiene esta muestra con la ayuda de expertos en desarrollo de Google.

Próximos pasos