Hola a todos!
Hace unos días, trabajando con unos condicionales en Typescript, tuve la necesidad de incluir en un if condicional varias condiciones. Aunque no puedo mostrar aquí el ejemplo concreto, he decidido utilizar otro ejemplo para crear esa estructura condicional.
Lo que haremos es mostrar el signo del zodiaco al que pertenece una persona según su fecha de nacimiento. Las fechas que he usado son las habituales que aparecen en los diarios y revistas, aunque como ya sabréis existen discrepancias entre algunas publicaciones:
Y según estos datos, crearemos una función que nos permita obtener el dato que buscamos. Por ejemplo, para Aries podemos construir así la condición, si el mes es igual a 3 y el día mayor o igual a 21 O el mes es igual a 4 y el día es menor o igual a 19 entonces será Aries. El operador lógico O se representa como dos barras ||( Aquí tenéis un enlace a la documentación).
if ((mes == 3 && dia >= 21) || (mes == 4 && dia <= 19)) {
signo = 'Aries';
Para construir nuestra función, emplearemos dos variables con la fecha que capturemos en nuestra hoja Excel, el mes y el día. Suficiente para crear nuestra función:
/**
* @customfunction
* @param {number[][]}
*/
function signoZodiaco(inicio) {
var ini = new Date(Math.round((inicio - 25569) * 86400 * 1000)).toLocaleDateString("en-US");
var nIni = new Date(Date.parse(ini) + 1* 24 * 60 * 60 * 1000);
var mes = (nIni.getUTCMonth() + 1)
var dia = nIni.getUTCDate()
var signo = "";
if ((mes == 3 && dia >= 21) || (mes == 4 && dia <= 19)) {
signo = 'Aries';
} else if ((mes == 4 && dia >= 20) || (mes == 5 && dia <= 20)) {
signo = 'Tauro';
} else if ((mes == 5 && dia >= 21) || (mes == 6 && dia <= 20)) {
signo = 'Géminis';
} else if ((mes == 6 && dia >= 21) || (mes == 7 && dia <= 22)) {
signo = 'Cáncer';
} else if ((mes == 7 && dia >= 23) || (mes == 8 && dia <= 22)) {
signo = 'Leo';
} else if ((mes == 8 && dia >= 23) || (mes == 9 && dia <= 22)) {
signo = 'Virgo';
} else if ((mes == 9 && dia >= 23) || (mes == 10 && dia <= 22)) {
signo = 'Libra';
} else if ((mes == 10 && dia >= 23) || (mes == 11 && dia <= 21)) {
signo = 'Escorpio';
} else if ((mes == 11 && dia >= 22) || (mes == 12 && dia <= 21)) {
signo = 'Sagitario';
} else if ((mes == 12 && dia >= 22) || (mes == 1 && dia <= 20)) {
signo = 'Capricornio';
} else if ((mes == 1 && dia >= 21) || (mes == 2 && dia <= 19)) {
signo = 'Acuario';
} else if ((mes == 2 && dia >= 20) || (mes == 3 && dia <= 20)) {
signo = 'Piscis';
}
return (signo)
}
Nuestra función se llamará signoZodiaco() y una vez registrada en nuestro editor funciona así de bien!:
Y esto es todo, espero que sea de utilidad!!
¿Te ha resultado de interés?, puedes apoyar a Excel Signum con una pequeña donación.
¡¡Muchas gracias!!
Mediante la suscripción al blog, la realización comentarios o el uso del formulario de contacto estás dando tu consentimiento expreso al tratamiento de los datos personales proporcionados según lo dispuesto en la ley vigente (LOPD). Tienes más información al respecto en esta página del blog: Política de Privacidad y Cookies