10 diciembre, 2023

EJEMPLO PRÁCTICO DE CÁLCULOS CON TYPESCRIPT

Hola a todos!

Espero que este calor que nos está sacudiendo estos días pase pronto!, de momento no queda otra alternativa que piscina, aire acondicionado y salir a la calle después del ocaso (como los vampiros!).

He sacado tiempo hoy para adaptar un post que escribí en 2020 (uno de los primeros post sobre typescript), en que planteaba un ejercicio de cálculo muy sencillo para obtener el coste de la Seguridad Social para una empresa en unas determinadas condiciones: EJEMPLO PRÁCTICO DE ALGUNOS CÁLCULOS CON TYPESCRIPT

Como este script era asíncrono, tengo este otro post que lo convierte al modelo actual: EJEMPLO PRÁCTICO DE ALGUNOS CÁLCULOS CON TYPESCRIPT: CONVIRTIENDO SCRIPT ASÍNCRONO HEREDADO AL MODELO ACTUAL

En cualquier caso, en estos ejemplos el método usado era: .setFormulas() que nos permite escribir una fórmula en typescript para que se ejecute de la misma forma en la hoja de Excel.

Para el ejemplo de hoy, os mostraré otra forma de hacerlo (con otro ejemplo):

Imaginad estos datos:

Para obtener las columnas Seguridad Social y Total, vamos a utilizar este código:

function main(workbook: ExcelScript.Workbook) {
	const miHoja = workbook.getWorksheet("Hoja1");
	const valores = miHoja.getUsedRange().getValues();
	const scadena: (string | number)[][] = [["SEG SOCIAL", "TOTAL"]];
	valores.splice(1).forEach((row) => {
		var ssocial = 0;
		var suma = 0
		var imp = +row[1];
		if (imp < 4139.4 * 12) {
			ssocial = imp * 31.4 / 100;
		} else {
			ssocial = 4139.4 * 12 * 31.4 / 100;
		}
		suma = imp + ssocial
		scadena.push(
			[ssocial, suma]
		)
	});
	const hojaDest = workbook.getWorksheet("Hoja1");
	const resultado = hojaDest.getRangeByIndexes(0, 2, scadena.length, scadena[0].length);
	resultado.setValues(scadena);
}

Lo que nos va a proporcionar este resultado:

Como podéis observar aquí no utilizar el método del post al que hago referencia, sino utilizando la información almacenada en matrices. Es un método que ya he utilizado en otros post y que recomiendo, como siempre, según cada caso particular.

¿Te ha resultado de interés?, puedes apoyar a Excel Signum con una pequeña donación.

Donate Button with Credit Cards

¡¡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

Comparte este post

Si te ha gustado o tienes alguna duda, puedes dejar aquí tu comentario.

Este sitio web utiliza cookies para que usted tenga la mejor experiencia de usuario. Si continúa navegando está dando su consentimiento para la aceptación de las mencionadas cookies y la aceptación de nuestra política de cookies, pinche el enlace para mayor información.plugin cookies

ACEPTAR
Aviso de cookies