Vba si múltiples condiciones
En este artículo, vamos a ver cómo utilizar la instrucción If Else If en Excel VBA utilizando un ejemplo adecuado.Implementación :En las pestañas de Microsoft Excel, seleccione la ficha Desarrollador. Inicialmente, la ficha Desarrollador puede no estar disponible. Ahora haga clic en la opción Visual Basic de la pestaña Desarrollador y cree un nuevo módulo para escribir el programa utilizando la sentencia Select Case.Desarrollador -> Visual Basic -> Herramientas -> MacrosIF ELSE IF La sintaxis es :If condition1/expression1 Then
End IfEn este principio, la condición If se ejecuta y si es TRUE entonces el bloque de código 1 se ejecutará y el programa termina. Ahora, si la condición 1 es FALSE entonces la condición 2 dentro de Else IF funcionará, y si es TRUE el bloque de código 2 se ejecutará y el programa terminará. Si las dos condiciones anteriores son falsas entonces funcionará Else y se ejecutará el bloque de código 3.Diagrama de flujo :Ejemplo : Supongamos que en una empresa necesitamos encontrar el salario máximo de tres departamentos : RRHH, Finanzas e IT.Código :Sub Find_Max()
Ejemplo de Excel ifthen else
El fragmento de código entre las palabras clave If y Then se denomina condición. Una condición es una sentencia que se evalúa como verdadero o falso. Se utilizan principalmente con bucles y sentencias If. Cuando creas una condición usas signos como >,<,<>,>=,<=,=.
Para evitar este tipo de problemas debemos utilizar dos condiciones. Éstas ayudan a establecer exactamente lo que se está buscando y eliminan cualquier confusión. El siguiente ejemplo muestra cómo utilizarlas. Veremos más condiciones múltiples en la sección siguiente.
La sentencia Else de VBA se utiliza como un cajón de sastre. Básicamente significa “si ninguna condición fuera verdadera” o “todo lo demás”. En el ejemplo de código anterior, no incluimos una instrucción de impresión para una marca de falla. Podemos agregar esto usando Else.
VBA tiene la sentencia IIf que funciona de la misma manera. Veamos un ejemplo. En el siguiente código usamos IIf para comprobar el valor de la variable val. Si el valor es mayor que 10 imprimimos true de lo contrario imprimimos false:
También puedes anidar sentencias IIf como en Excel. Esto significa usar el resultado de un IIf con otro. Añadamos otro tipo de resultado a nuestros ejemplos anteriores. Ahora queremos imprimir Distinción, Aprobado o Suspenso para cada estudiante.
Ifthen en vba
En este ejemplo, la fórmula en la celda D2 dice: IF(C2 = 1, then return Yes, otherwise return No)Como ves, la función IF puede usarse para evaluar tanto texto como valores. También puede utilizarse para evaluar errores. No se limita a comprobar si una cosa es igual a otra y devolver un único resultado, también puede utilizar operadores matemáticos y realizar cálculos adicionales en función de sus criterios. También puede anidar varias funciones IF para realizar varias comparaciones.
En la ilustración anterior, en lugar de devolver un resultado de texto, vamos a devolver un cálculo matemático. Así que la fórmula en E2 dice IF(Actual is Greater than Budgeted, then Subtract the Budgeted amount from the Actual amount, otherwise return nothing).
Si valor vba
Utilice la sentencia If…Then…Else para ejecutar una sentencia específica o un bloque de sentencias, dependiendo del valor de una condición. Las sentencias If…Then…Else pueden anidarse en tantos niveles como necesite.
Puede añadir sentencias ElseIf a una sentencia If…Then…Else para comprobar una segunda condición si la primera es False. Por ejemplo, el siguiente procedimiento de función calcula una bonificación basada en la clasificación del trabajo. La sentencia que sigue a la sentencia Else se ejecuta si las condiciones de todas las sentencias If y ElseIf son False.