Este será uno de varios post que voy a publicar sobre protección de hojas, libros y celdas con Typescript en Excel Online.
En el post de hoy os mostraré un script para proteger todas las hojas del un libro (y desprotegerlas). Es un código muy sencillo y con el que podremos proteger nuestra información.
Imaginad que tenemos dos hojas en nuestro libro y las queremos proteger con la siguiente contraseña: xWm1q.
async function main(workbook: ExcelScript.Workbook) {
var nHojas = workbook.getWorksheets();
nHojas.forEach((sheet) => {
if (sheet.getProtection().getProtected() == false) {
sheet.getProtection().protect({},"xWm1q")
console.log(sheet.getName() + ' ' + 'protegida')
}
else {
sheet.getProtection().unprotect("xWm1q")
console.log(sheet.getName() + ' ' + 'desprotegida')
}
});
}
Con el siguiente código recorremos todas las hojas y verificamos que si no están protegidas realizaremos la protección de la hoja y en caso contrario las desprotegeremos.

En la imagen podéis ver como la hoja resulta protegida y también como aparece en los resultados que cada hoja ha sido protegida.
Además se incluye una contraseña para ofrecer mayor seguridad. En caso de no ser necesaria, solo se tendría que dejar los () al final de cada método: .protect() o .unprotect().
Como es obvio el if condicional se puede programar para verificar si la hoja no está protegida (el caso del ejemplo) o si está protegida (para lo cual debemos cambiar el false a true) e intercambiar el protect con el unprotect. Os lo dejo a vuestra elección, el ejemplo es únicamente para comprobar cómo funciona la protección de las hojas.
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