Buscar este blog
En este Blog puedes encontrar Información para comenzar a programar por medio de: un poco de historia de programación, conceptos de programación, ejemplos sencillos con lenguajes de programación como : PHP,HTML, Javascript,Delphi, Visual Basic,Python, Progress 4gl,C++,SQL, entre otros. La programación es para todos, en un proyecto de desarrollo de Software se requieren equipos multidisciplinarios y es bueno que todos comprendan que implica desarrollar Software.
Destacado
- Obtener vínculo
- Correo electrónico
- Otras apps
Macros en Google Sheets
Google tiene una versión gratuita para Hojas de cálculo mejor conocidas por el software más utilizado del mundo Excel de Microsoft, en días anteriores tenía que crear una plantilla en Google Sheets pero tenía que hacer lo mismo que hacía mi plantilla en Excel, solo que mi plantilla tiene macros y de ahí el tema de hoy: explicarles como es que pueden incorporar macros en Google Sheets.
- Primer paso entender la lógica de mi programa, cuales eran los pasos en visual basic.
- Pensé que lo mas fácil era hacer una traducción del código de mi macro al código de Google Sheet, así que abrí mi macro de Excel y comencé buscar como se llamaban las instrucciones y buscar en Google la instrucción de equivalencia.
- Comenzar a probar cada línea que agregaba, para ver que hicieran la funcionalidad que yo quería.
- Mejorar la macro de Visual Basic.
El resultado final es
El código que utilice
/** @OnlyCurrentDoc */
function Calcular_consolidado_periodo() {
var vcperiodo = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Plantilla").getRange("M2").getValue();
SpreadsheetApp.getUi().alert(vcperiodo);
var vifilain = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Resumen").getLastRow() ;
var vifila = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Resumen").getLastRow() ;
var indcat = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Categorias").getLastRow() ;
var vctotal = 0;
var vifila2 = 3;
var indicecat = 1;
var categoria = "";
vifila = vifila + 1;
do{
categoria = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Categorias").getRange(indicecat, 1).getValue()
SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Resumen").getRange(vifila, 2).setValue(categoria);
indicecat = indicecat + 1;
vifila = vifila + 1;
}while(indicecat < indcat);
vifila = vifilain;
vifila = vifila + 1;
do {
vifila2 = 3
vctotal = 0
do{
if (SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Plantilla").getRange(vifila2, 5).getValue() == vcperiodo &&
SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Plantilla").getRange(vifila2, 2).getValue() ==
SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Resumen").getRange(vifila, 2).getValue())
{
var valor = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Plantilla").getRange(vifila2, 4).getValue();
vctotal = vctotal + valor;
}
vifila2 = vifila2 + 1
}while (SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Plantilla").getRange(vifila2, 5).getValue() != "");
SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Resumen").getRange(vifila, 1).setValue(vcperiodo);
SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Resumen").getRange(vifila, 3).setValue(vctotal);
vifila = vifila + 1 ;
} while (SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Resumen").getRange(vifila, 2).getValue() != "" );
};
El código de la Macro en Excel vs Google Sheets
El tema me parece muy interesante, porque también como veíamos en otro post previo TypeScript el nuevo lenguaje utilizado para programar macros online Typescript el sustituto de VB también esta basado en Javascript, cada vez veo más aplicaciones a este lenguaje.
Espero esta pagina les sea de utilidad, nos sigan, nos compartan en este blog o en la página de Facebook https://www.facebook.com/Programacionparatodosmsg/
- Obtener vínculo
- Correo electrónico
- Otras apps
Entradas populares
Graficar funciones en Python
- Obtener vínculo
- Correo electrónico
- Otras apps
Ejemplo Macro en Word
- Obtener vínculo
- Correo electrónico
- Otras apps
Comentarios
Publicar un comentario