Sesión Nro. 02 Tipos de Datos, Variables, Constantes y Sentencias Condicionales Objetivo Los objetivos principales de la presente sesión son que el alumno conozca: • • • • • El uso de la ventana de código Los diferentes tipos de datos Como declarar una variable y el respectivo alcance que puede tener Como declarar constantes y el respectivo alcance que puede tener El Manejo de las estructuras de decisión Tabla de Contenido • • • • • • • • • • • • Trabajando con la Ventana de Código Editando Código Cuadro de Mensaje y Cuadro de Entrada Constantes Predefinidas Operadores Tipos de Datos Variables Constantes Convenciones para nombres de Constantes y Variables Estructuras de Control ( De Decisión ) Ejercicio 01 Ejercicio 02 InfoTec Data S02 1/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Trabajando con la Ventana de Código Código es un término general para todas las sentencias Visual Basic que usted escribe en una aplicación: procedimientos de evento y procedimientos generales. El código en Visual Basic se escribe en la ventana de Código. El editor de texto es solo un editor ASCII con colores para diferenciar las palabras claves en el código que escribe. Módulos de Formulario Cada formulario en su aplicación tiene un módulo de formulario asociado, estos son guardados con una extensión de archivo FRM y contienen: • • • Los valores de las propiedades para el formulario y sus controles. Declaración de variables en el ámbito del formulario. Procedimientos de evento y procedimientos generales en el ámbito del formulario. Nota Las descripciones gráficas de un formulario y los controles sobre el formulario son guardados en formato binario en un archivo con extensión FRX. Módulos Estándar Los módulos estándar pueden contener código que es común a varios formularios en su aplicación. Este código es por omisión público, lo cual significa que fácilmente compartido con otros módulos de código, tales como un módulo de formulario. Estos módulos contienen declaraciones de procedimientos, tipos y variables. No pueden almacenar procedimientos de evento por que no contienen objetos. La Ventana de Código La Ventana de Código se usa para escribir, mostrar y editar el código de su aplicación. Puede abrir una ventana de código por cada módulo de su aplicación, de modo que puede fácilmente copiar y pegar entre ellos. La Ventana de Código contiene: • • • • • 2/32 El cuadro: Objeto El cuadro: Evento La barra de división Botón Ver: Procedimiento Botón Ver: Módulo Completo S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión El Cuadro Objeto Muestra el nombre del objeto seleccionado. Haga clic en la flecha a la derecha del cuadro Objeto para mostrar una lista de todos los objetos asociados con el formulario. El Cuadro Evento Muestra todos los eventos reconocidos para el formulario o control mostrado en el cuadro Objeto. Cuando seleccionamos un evento, en la ventana de código se muestra el procedimiento de evento asociado con ese evento. La Barra de División Desde el menú Ventana puede ejecutar el comando Dividir para dividir la ventana de código en dos partes, cada una de las cuales se desplaza separadamente. Puede entonces ver diferentes partes de su código al mismo tiempo. La información que aparece en el cuadro Objeto y Evento se refiere al código en la parte que tiene el enfoque. El mismo comando utilizado para dividir la ventana puede utilizarlo para cerrar una de sus partes o también lo puede hacer arrastrando la barra de división hacia la parte superior o inferior de la ventana. Botón Ver Procedimiento Establece que en la ventana de código se edite un procedimiento a la vez. Botón Ver Módulo Completo Establece que en la ventana de código se tenga acceso a todos los procedimientos, separados por una línea separadora uno de otro. InfoTec Data S02 3/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Editando Código Use las características de edición de Visual Basic para que su código sea más fácil de leer. Sangría Use la sangría para diferenciar partes de su código, tales como estructuras repetitivas y condicionales. Para aplicar sangría a una sección se sentencias de código use la tecla Tab o el comando Aplicar sangría del menú Edición. Se forma similar, Shift + Tab o el comando Anular sangría del menú Edición quitará una sangría a las líneas seleccionadas. Ejemplo 01 Private Sub cmdAceptar_Click() If Len(Trim(txtUsuario)) = 0 Then txtUsuario.SetFocus ElseIf Len(Trim(txtContraseña)) = 0 Then txtContraseña.SetFocus ElseIf txtContraseña = "CEPS" Then MsgBox "Bien, su clave es correcta" Unload Me Else MsgBox "Mal, su clave no es correcta" txtContraseña.SelStart = 0 txtContraseña.SelLength = Len(Trim(txtContraseña)) txtContraseña.SetFocus End If End Sub Carácter de continuación de línea El carácter subrayado (_) es el carácter de continuación de línea, y se usa para dividir una sentencia en múltiples líneas. Esto hace que la sentencia sea más fácil de leer porque esta contenida totalmente dentro de la ventana de código en lugar de extenderse mas allá de sus límites. El carácter de continuación de línea se coloca luego de un espacio, como se puede apreciar en el siguiente ejemplo. Ejemplo 02 MsgBox Prompt := “La contraseña no es correcta”, _ Buttons := vbOkOnly + vbExclamation, _ Title := “Mensaje” 4/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Comentarios El añadir documentación y comentarios a su código permite comprender mejor lo que hace el código. Esto también ayuda a comprender el código si necesita volver a revisarlo en alguna fecha posterior. Un comentario se inicia con el carácter apóstrofe (‘), de modo que todo el texto que continúe a este carácter será ignorado en la ejecución de la aplicación. Ejemplo 03 Private Sub cmdLimpiar_Click() ‘Este procedimiento limpia la ventana de identificación txtUsuario.Text = “” ‘Limpia el cuadro de texto Usuario txtContraseña.Text = “” ‘Limpia el cuadro de texto Contraseña txtUsuario.SetFocus ‘Mueve el enfoque en el cuadro de texto Usuario End Sub InfoTec Data S02 5/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Cuadro de Mensaje y de Entrada Una de las formas más simples de obtener información para y desde el usuario es utilizando las funciones MagBox e InputBox respectivamente. Función: MsgBox() Los cuadros de mensaje ofrecen un modo simple y rápido de consultar a los usuarios por información simple o para permitirles tomar decisiones sobre el camino que su programa debe tomar. Puede usar esta función para mostrar diferentes tipos de mensaje y botones con los cuales el usuario da una respuesta. Sintaxis MsgBox( prompt [, buttons] [, title] [, helpfile, context] ) La sintaxis de la función MsgBox consta de los siguientes argumentos: Argumento Descripción Prompt Requerido. Expresión de cadena que representa el prompt en el cuadro de diálogo. La longitud máxima de prompt es de aproximadamente 1024 caracteres, según el ancho de los caracteres utilizados. Si prompt consta de más de una línea, puede separarlos utilizando un carácter de retorno de carro (Chr(13)) o un carácter de avance de línea (Chr(10)), o una combinación de caracteres de retorno de carro - avance de línea (Chr(13) y Chr(10)) entre cada línea y la siguiente. Buttons Opcional. Expresión numérica que corresponde a la suma de los valores que especifican el número y el tipo de los botones que se pretenden mostrar, el estilo de icono que se va a utilizar, la identidad del botón predeterminado y la modalidad del cuadro de mensajes. Si se omite este argumento, el valor predeterminado para buttons es 0. Title Opcional. Expresión de cadena que se muestra en la barra de título del cuadro de diálogo. Si se omite title, en la barra de título se coloca el nombre de la aplicación. Helpfile Opcional. Expresión de cadena que identifica el archivo de Ayuda que se utiliza para proporcionar ayuda interactiva en el cuadro de diálogo. Si se especifica helpfile, también se debe especificar context. Opcional. Expresión numérica que es igual al número de contexto de Ayuda asignado por el autor al tema de Ayuda correspondiente. Si se especifica context, también se debe especificar helpfile. Context 6/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Valores El argumento buttons puede asumir los siguientes valores: Constante Valor Descripción vbOKOnly vbOKCancel vbAbortRetryIgnore vbYesNoCancel vbYesNo vbRetryCancel 0 1 2 3 4 5 Muestra solamente el botón Aceptar. Muestra los botones Aceptar y Cancelar. Muestra los botones Anular, Reintentar e Ignorar. Muestra los botones Sí, No y Cancelar. Muestra los botones Sí y No. Muestra los botones Reintentar y Cancelar. vbCritical vbQuestion vbExclamation vbInformation 16 32 48 64 Muestra el icono de mensaje crítico. Muestra el icono de pregunta de advertencia. Muestra el icono de mensaje de advertencia. Muestra el icono de mensaje de información. vbDefaultButton1 vbDefaultButton2 vbDefaultButton3 vbDefaultButton4 0 256 512 768 El primer botón es el predeterminado. El segundo botón es el predeterminado. El tercer botón es el predeterminado. El cuarto botón es el predeterminado. vbApplicationModal vbSystemModal 0 4096 Aplicación modal; el usuario debe responder al cuadro de mensajes antes de poder seguir trabajando en la aplicación actual. Sistema modal; se suspenden todas las aplicaciones hasta que el usuario responda al cuadro de mensajes. El primer grupo de valores (0 a 5) describe el número y el tipo de los botones mostrados en el cuadro de diálogo; el segundo grupo (16, 32, 48, 64) describe el estilo del icono, el tercer grupo (0, 256, 512, 768) determina el botón predeterminado y el cuarto grupo (0, 4096) determina la modalidad del cuadro de mensajes. Cuando se suman números para obtener el valor final del argumento buttons, se utiliza solamente un número de cada grupo. Nota Estas constantes las especifica Visual Basic for Applications. Por tanto, el nombre de las mismas puede utilizarse en cualquier lugar del código en vez de sus valores reales. InfoTec Data S02 7/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Valores devueltos Constante vbOK vbCancel vbAbort vbRetry vbIgnore vbYes vbNo Valor 1 2 3 4 5 6 7 Descripción Aceptar Cancelar Anular Reintentar Ignorar Sí No Nota Si desea omitir algún argumento, debe incluir el delimitador de coma correspondiente o utilizar argumentos con nombre. Ejemplo 04 iRpta = MsgBox( Prompt := "¿Desea guardar los cambios?", _ Buttons := vbYesNo + vbExclamation + vbDefaultButton2, _ Title := "Documento alterado") If iRpta = vbYes Then End If Ejemplo 05 strMsg = “¿Desea Continuar?” iEstilo = vbYesNo + vbExclamation + vbDefaultButton2 strTitulo = “Responda” iRpta = MsgBox( strMsg, iEstilo, strTitulo ) If iRpta=vbYes Then −−−−−−−− −−−−−−−− Else −−−−−−−− −−−−−−−− End If 8/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Ejemplo 06 strMsg = “¿Desea Continuar?” iEstilo = vbYesNo + vbExclamation + vbDefaultButton2 strTitulo = “Responda” iRpta = MsgBox( _ Prompt := strMsg, _ Title := strTitulo, _ Buttons := iEstilo ) If iRpta=vbYes Then −−−−−−−− −−−−−−−− Else −−−−−−−− −−−−−−−− End If InfoTec Data S02 9/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Función InputBox() Sintaxis InputBox( prompt [, title] [, default] [, xpos] [, ypos] [, helpfile, context] ) La sintaxis de la función InputBox consta de los siguientes argumentos con nombre: 10/32 Parte Descripción Prompt Requerido. Expresión de cadena que se muestra como mensaje en el cuadro de diálogo. La longitud máxima de prompt es de aproximadamente 1024 caracteres, según el ancho de los caracteres utilizados. Si prompt consta de más de una línea, puede separarlos utilizando un carácter de retorno de carro (Chr(13)), un carácter de avance de línea (Chr(10)) o una combinación de los caracteres de retorno de carro - avance de línea (Chr(13) y Chr(10)) entre cada línea y la siguiente. Title Opcional. Expresión de cadena que se muestra en la barra de título del cuadro de diálogo. Si omite title, en la barra de título se coloca el nombre de la aplicación. Default Opcional. Expresión de cadena que se muestra en el cuadro de texto como respuesta predeterminada. Si omite default, se muestra el cuadro de texto vacío. Xpos Opcional. Expresión numérica que especifica, la distancia en sentido horizontal entre el borde izquierdo del cuadro de diálogo y el borde izquierdo de la pantalla. Si se omite xpos, el cuadro de diálogo se centra horizontalmente. Ypos Opcional. Expresión numérica que especifica, la distancia en sentido vertical entre el borde superior del cuadro de diálogo y el borde superior de la pantalla. Si se omite ypos, el cuadro de diálogo se coloca a aproximadamente un tercio de la altura de la pantalla, desde el borde superior de la misma. Helpfile Opcional. Expresión de cadena que identifica el archivo de Ayuda que se utilizará para proporcionar ayuda interactiva para el cuadro de diálogo. Si se especifica helpfile, también deberá especificarse context. Context Opcional. Expresión numérica que es el número de contexto de Ayuda asignado por el autor al tema de Ayuda correspondiente. Si se especifica context, también deberá especificarse helpfile. S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Comentarios Si el usuario hace clic en Cancelar, la función devuelve una cadena de caracteres de longitud cero (""). Nota Si desea omitir algunos argumentos, debe incluir el delimitador de coma correspondiente o utilizar argumentos con nombre. Ejemplo 07 StrUsuario = InputBox( _ Prompt:="Por favor ingrese su nombre", _ Title:="Identifiquese", _ Default:="Sergio") Ejemplo 08 strNombre = InputBox( “¿Cual es su nombre?”,”Identificación” ) Ejemplo 09 Mensaje = " Introduzca un número del 1 a 3" ' Establece el mensaje. Título = "Demostración de InputBox" ' Establece el título. ValorPred = "1" ' Establece el valor predeterminado. ' Muestra el mensaje, el título, y el valor predeterminado. MiValor = InputBox(Mensaje, Título, ValorPred) Select Case MiValor Case 1 −−−−−−−− −−−−−−−− Case 2 −−−−−−−− −−−−−−−− Case 3 −−−−−−−− −−−−−−−− Case Else −−−−−−−− −−−−−−−− End Select InfoTec Data S02 11/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Constantes Predefinidas Visual Basic reconoce cierta cantidad de constantes predefinidas que pueden ser usadas en cualquier parte de su código en lugar de valores numéricos. Puede hacer que su código sea más fácil de leer y escribir mediante el uso de estas constantes. Además, los valores de estas constantes pueden cambiar en versiones posteriores de Visual Basic, su uso permitirá que su código sea compatible. Por ejemplo, la propiedad WindowState puede aceptar las siguientes constantes: Constante vbNormal vbMinimized vbMaximized Valor 0 1 2 Descripción Normal Minimizado Maximizado Ejemplo 10 Por ejemplo, para establecer el estado del formulario frmEntrada en maximizado, la sentencia sería: frmEntrada.WindowState = vbMaximized 12/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Operadores Aritméticos ˆ * / \ Mod + & Exponenciación Multiplicación División División entera Residuo entero (Ejm: A Mod B) Suma Resta Concatenación de cadenas Comparación = <> < > <= >= Like * ? # [lista] [!lista] Is Igual Distinto Menor que Mayor que Menor o igual Mayor o igual Compara dos cadenas cero o más caracteres (Ejm: cad Like “ma*”) Cualquier caracter Cualquier dígito (0-9) cualquier carácter en lista cualquier carácter que no esta en lista Usado para comparar dos variables de referencia a objetos Lógicos And Or Xor Not InfoTec Data “Y” lógico “O” lógico “O” Exclusivo Negación S02 13/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Tipos de datos Un tipo de dato determina la naturaleza del dominio de valores que puede tomar una variable, las operaciones en que puede participar y el espacio de memoria que necesita. La tabla siguiente muestra los tipos de datos, incluyendo el tamaño de almacenamiento y el intervalo. Tipo de Dato Byte Boolean Integer Long (entero largo) Single (coma flotante/ precisión simple) Double (coma flotante/ precisión doble) Currency (entero a escala) Decimal Date Object String (longitud variable) String (longitud fija) Variant (con números) Variant (con caracteres) Definido por el usuario (utilizando Type) Tamaño de Almacenamiento 1 byte 2 bytes 2 bytes 4 bytes 4 bytes 8 bytes 8 bytes 14 bytes 8 bytes 4 bytes 10 bytes + longitud de la cadena Longitud de la cadena 16 bytes Rango 0 a 255 True o False -32.768 a 32.767 -2.147.483.648 a 2.147.483.647 -3,402823E38 a –1,401298E-45 para valores negativos; 1,401298E-45 a 3,402823E38 para valores positivos -1,79769313486232E308 a -4,94065645841247E-324 para valores negativos; 4,94065645841247E-324 a 1,79769313486232E308 para valores positivos -922.337.203.685.477,5808 a 922.337.203.685.477,5807 +/-79.228.162.514.264.337.593.543.950.335 sin punto decimal; +/-7,9228162514264337593543950335 con 28 posiciones a la derecha del signo decimal; el número más pequeño distinto de cero es +/- 0,0000000000000000000000000001 1 de enero de 100 a 31 de diciembre de 9999 Cualquier referencia a tipo Object Desde 0 a 2.000 millones Desde 1 a 65.400 aproximadamente Cualquier valor numérico hasta el intervalo de un tipo Double 22 bytes + longitud de El mismo intervalo que para un tipo String de cadena longitud variable Número requerido El intervalo de cada elemento es el mismo que el por los elementos intervalo de su tipo de datos. Nota Las matrices de cualquier tipo de datos requieren 20 bytes de memoria más cuatro bytes para cada dimensión de matriz, más el número de bytes que ocupan los propios datos. Por ejemplo, los datos de una matriz unidimensional que consta de cuatro elementos de datos tipo Integer de dos bytes cada uno, ocupan ocho bytes. Los ocho bytes que requieren los datos más los 24 bytes necesarios para la matriz suman un requisito total de memoria de 32 bytes para dicha matriz. Un tipo Variant que contiene una matiz requiere 12 bytes más que la matriz por sí sola. 14/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Convertir tipos de datos Visual Basic proporciona varias funciones de conversión que puede utilizar para convertir valores en tipos de datos específicos. Por ejemplo, para convertir un valor a Currency, utilice la función CCur: PagoPorSemana = CCur(horas * PagoPorHora) La siguiente tabla muestra las funciones de conversión: Funcion Cbool Cbyte Ccur Cdate CDbl Cint CLng CSng CStr Cvar CVErr Convierten una expresión en Boolean Byte Currency Date Double Integer Long Single String Variant Error Nota Los valores que se pasan a una función de conversión deben ser válidos para el tipo de dato destino o se producirá un error. Por ejemplo, si intenta convertir un tipo Long en un Integer, el tipo Long debe estar en el intervalo válido del tipo de dato Integer. Variables Las variables se utilizan para almacenar valores temporalmente durante la ejecución de una aplicación. Las variables tienen un nombre (la palabra que utiliza para referirse al valor que contiene la variable) y un tipo de dato (que determina el topo de dato que la variable puede almacenar). Almacenamiento y recuperación de datos en variables Utilice una sentencia de asignación para realizar cálculos y asignar el resultado a una variable: Ejemplo 11 ManzanasVendidas = 10 ' Se pasa el valor 10 a la variable ManzanasVendidas = ManzanasVendidas + 1 Observe que el signo igual del ejemplo es un operador de asignación, no un operador de igualdad; el valor 10 se asigna a la variable ManzanasVendidas. InfoTec Data S02 15/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Declaración de variables Declarar una variable es decirle al programa algo de antemano. Se declara una variable mediante la instrucción Dim, proporcionando un nombre a la variable, según la siguiente sintaxis. Sintaxis Dim nombre_variable [As tipo] Las variables que se declaran en un procedimiento mediante la sentencia Dim sólo existen mientras se ejecuta el procedimiento. Cuando termina el procedimiento, desaparece el valor de la variable. Además, el valor de una variable de un procedimiento es local a dicho procedimiento; es decir, no puede tener acceso a una variable de un procedimiento desde otro procedimiento. Estas características le permiten utilizar los mismos nombres de variables en distintos procedimientos sin preocuparse por posibles conflictos o modificaciones accidentales. El nombre de una variable debe cumplir con los siguientes requisitos: • • • • Debe comenzar con una letra. No puede incluir un punto o un carácter de declaración de tipo ($,&,!,%,#,@). No debe exceder de 255 caracteres. Debe ser única en el mismo alcance, que es el intervalo desde el que se puede hacer referencia a la variable: un procedimiento, formulario, etc. La cláusula opcional As tipo de la sentencia Dim le permite definir el tipo de dato o de objeto de la variable que va a declarar. Los tipos de datos definen el tipo de información que almacena la variable. Algunos ejemplos de tipos de datos son String, Integer y Currency. Las variables también pueden contener objetos de Visual Basic u otras aplicaciones. Algunos ejemplos de tipos de objeto de Visual Basic, o clases, son Object, Form1 y TextBox. Hay otras formas de declarar variables: • • • 16/32 Declarar una variable en la sección Declaraciones de un módulo de formulario, estándar o de clase, en vez de en un procedimiento, hace que la variable esté disponible para todos los procedimientos del módulo. Declarar una variable mediante la palabra clave Public hace que esté accesible para toda la aplicación. Declarar una variable local mediante la palabra clave Static conserva su valor aunque termine el procedimiento. S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Declaración implícita No tiene por qué declarar una variable antes de utilizarla. Por ejemplo, podría escribir una función donde no hiciera falta declarar TempVal como se ilustra en el ejemplo 12. Ejemplo 12 Function Raíz(num) TempVal = Abs(num) Raíz = Sqr(TempVal) End Function Visual Basic crea automáticamente una variable con ese nombre, que puede utilizar como si la hubiera declarado explícitamente. Aunque es cómodo, puede provocar errores sutiles en el código si se equivoca de nombre de variable, como se ilustra en el ejemplo 13. Ejemplo 13 Function Raíz(num) TempVal = Abs(num) Raíz = Sqr(TemVal) End Function A primera vista, la función del ejemplo 12 parece igual a la función del ejemplo 13, pero como se ha escrito erróneamente la variable TempVal en la tercera línea del ejemplo 13, la función devolverá siempre cero. Cuando Visual Basic encuentra un nombre nuevo, no puede averiguar si realmente desea declarar una variable nueva o simplemente ha escrito de forma errónea una variable existente, por lo que crea una variable nueva con ese nombre. InfoTec Data S02 17/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Declaración explícita Para evitar problemas al equivocarse de nombre en las variables, puede configurar a que Visual Basic le avise siempre que encuentre un nombre que no se haya declarado explícitamente como una variable. Para declarar variables de forma explícita incluya la sentencia Option Explicit en la sección Declaraciones Generales del módulo de clase, de formulario o estándar: Usted puede configurar Visual Basic para que inserte automáticamente esta sentencia, en este caso de ir al menú Herramientas, elija Opciones, haga clic en la ficha Editor y active la opción Declaración de variables requerida. Esto funciona solo con los módulos nuevos, pero no en los ya creados, por los que tendrá que hacerlo manualmente. Si hubiera tenido efecto dicha instrucción en el módulo de formulario o módulo estándar que contiene la función Raíz, Visual Basic habría reconocido TempVal y TemVal como variables no declaradas y habría generado errores para ambas. Debería, por tanto, declarar explícitamente TempVal, como se muestra en el ejemplo 14. Ejemplo 14 Function Raíz(num) Dim TempVal TempVal = Abs(num) Raíz = Sqr(TemVal) End Function Ahora podrá comprender el problema inmediatamente porque Visual Basic habrá mostrado un mensaje de error para la variable TemVal que se ha escrito de forma incorrecta. Como la instrucción Option Explicit le ayuda a interceptar esta clase de errores, es conveniente utilizarla en todo el código. 18/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Alcance de las variables El alcance de una variable define en qué partes del código son reconocidas. Cuando declara una variable en un procedimiento, sólo el código de dicho procedimiento puede tener acceso o modificar el valor de la variable; tiene un alcance local al procedimiento. A veces, sin embargo, se necesita utilizar una variable con un alcance más general, como aquella cuyo valor está disponible para todos los procedimientos del mismo módulo o incluso para todos los procedimientos de toda la aplicación. Visual Basic le permite especificar el alcance de una variable cuando la declara. Estableciendo el alcance de las variables Dependiendo de cómo se declara, una variable tiene como alcance un procedimiento (local) o un módulo. Alcance Privado Público Nivel de procedimiento Las variables son privadas al No es aplicable. No puede procedimiento donde se declarar variables públicas declaran. dentro de un procedimiento. Nivel de módulo Las variables son privadas al Las variables están disponibles para todos los módulos. módulo donde se declaran. Variables utilizadas en un procedimiento Las variables al nivel de procedimiento sólo se reconocen en el procedimiento en el que se han declarado. Se las conoce también como variables locales. Se declaran mediante las palabras clave Dim o Static. Ejemplo 15 Dim intTemp As Integer Static intContador As Integer Los valores de variables locales declaradas con Static existen mientras se ejecuta la aplicación, mientras que las variables declaradas con Dim sólo existen mientras se ejecuta el procedimiento. InfoTec Data S02 19/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Variables utilizadas en un módulo De forma predeterminada, una variable al nivel de módulo está disponible para todos los procedimientos del módulo, pero no para el código de otros módulos. Cree variables al nivel de módulo declarándolas con la palabra clave Private en la sección Declaraciones Generales al principio del módulo. Por ejemplo: Ejemplo 16 Private intTemp As Integer Al nivel de módulo, no hay diferencia entre Private y Dim, pero es preferible usar Private porque contrasta con Public y hace que el código sea más fácil de comprender. Variables utilizadas por todos los módulos Para hacer que una variable al nivel de módulo esté disponible para otros módulos, utilice la palabra clave Public para declararlas. Los valores de las variables públicas están disponibles para todos los procedimientos de la aplicación. Al igual que todas las variables al nivel de módulo, las variables públicas se declaran en la sección Declaraciones Generales al principio del módulo. Ejemplo 17 Public intTemp As Integer Nota No puede declarar variables públicas en un procedimiento, sólo en la sección Declaraciones Generales de un módulo. 20/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Constantes A menudo verá que el código contiene valores constantes que reaparecen una y otra vez. O puede que el código dependa de ciertos números que resulten difíciles de recordar (números que, por sí mismos, no tienen un significado obvio). En estos casos, puede mejorar mucho la legibilidad del código y facilitar su mantenimiento si utiliza constantes. Una constante es un nombre significativo que sustituye a un número o una cadena que no varía. Aunque una constante recuerda ligeramente a una variable, no puede modificar una constante o asignarle un valor nuevo como ocurre con una variable. Hay dos orígenes para las constantes: • • Constantes intrínsecas o definidas por el sistema proporcionadas por Visual Basic. Las constantes simbólicas o definidas por el usuario se declaran mediante la instrucción Const. Creación de sus propias constantes Sintaxis [Public|Private] Const nombre_constante [As tipo] = expresión El argumento nombre_constante es un nombre simbólico válido (las reglas son las mismas que para crear nombres de variable) y expresión está compuesta por constantes y operadores de cadena o numéricos; sin embargo, no puede utilizar llamadas a funciones en expresión. Una instrucción Const puede representar una cantidad matemática o de fecha y hora: Ejemplo 18 Const conPi = 3.14159265358979 Public Const conMaxPlanetas As Integer = 9 Const conFechaSalida = #1/1/95# Ejemplo 19 Se puede utilizar también la instrucción Const para definir constantes de cadena. Public Const conVersion = "07.10.A" Const conNombreClave = "Enigma" Ejemplo 20 Puede colocar más de una declaración de constante en una única línea si las separa con comas. Public Const conPi=3.14, conMaxPlanetas=9, conPobMundial=6E+09 InfoTec Data S02 21/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Ejemplo 21 A menudo, la expresión del lado derecho del signo igual ( = ) es un número o cadena literal, pero también puede ser una expresión que dé como resultado un número o una cadena (aunque la expresión no puede contener llamadas a funciones). Puede incluso definir constantes en términos de constantes previamente definidas: Const conPi2 = conPi * 2 Ejemplo 22 Una vez que defina las constantes, puede colocarlas en el código para hacerlo más legible. Por ejemplo: Static SistemaSolar(1 To conMaxPlanetas) If numPersonas > conPopMundial Then Exit Sub Alcance de las constantes definidas por el usuario Una instrucción Const tiene igual alcance que una declaración de variable y se le aplican las mismas reglas: • • • Para crear una constante que sólo exista en un procedimiento, declárela dentro del procedimiento. Para crear una constante disponible para todos los procedimientos de un módulo, pero no para el código que está fuera del módulo, declárela en la sección Declaraciones Generales del módulo. Para crear una constante disponible en toda la aplicación, declare la constante en la sección Declaraciones Generales de un módulo estándar y coloque delante de Const la palabra clave Public. No se pueden declarar las constantes públicas en un módulo de clase o de formulario. Evitar referencias circulares Como es posible definir constantes en términos de otras constantes, deberá tener cuidado para no establecer un ciclo o referencia circular entre dos o más constantes. Se produce un ciclo cuando se tienen dos o más constantes públicas, cada una de las cuales está definida en función de la otra. Ejemplo 23 ' En el Módulo 1: Public Const conA = conB * 2 ' Disponible en toda la aplicación. ' En el Módulo 2: Public Const conB = conA / 2 ' Disponible en toda la aplicación. Si se produce un ciclo, Visual Basic generará un error cuando intente ejecutar la aplicación. No puede ejecutar el código hasta que resuelva la referencia circular. Para evitar la creación de un ciclo, restrinja todas las constantes públicas a un único módulo o, al menos, al menor número posible de módulos. 22/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Convenciones para nombres de constantes y variables Las variables se deben definir siempre con el menor alcance posible. Las variables globales (públicas) pueden hacer la lógica de una aplicación muy difícil de entender. Las variables globales también hacen mucho más difícil mantener y volver a usar el código. En Visual Basic las variables pueden tener el alcance siguiente: Alcance Declaración Visible en Nivel de procedimiento Dim o Static en el procedimiento, El procedimiento en el que subprocedimiento o función está declarada Nivel de módulo Private en la sección Todos los procedimientos Declaraciones Generales de un del módulo de formulario o módulo de formulario o de código de código (.frm, .bas) Global Public en la sección En toda la aplicación Declaraciones Generales de un módulo de código (.bas) En una aplicación de Visual Basic, las variables globales se deben usar sólo cuando no exista ninguna otra forma cómoda de compartir datos entre formularios. Cuando haya que usar variables globales, es conveniente declararlas todas en un único módulo agrupadas por funciones y dar al módulo un nombre significativo que indique su finalidad, como Publicas. Una práctica de codificación correcta es escribir código modular siempre que sea posible. Por ejemplo, si la aplicación muestra un cuadro de diálogo, coloque todos los controles y el código necesario para ejecutar la tarea del diálogo en un único formulario. Esto ayuda a tener el código de la aplicación organizado en componentes útiles y minimiza la sobrecarga en tiempo de ejecución. A excepción de las variables globales (que no se deberían pasar), los procedimientos y funciones deben operar sólo sobre los objetos que se les pasan. InfoTec Data S02 23/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Prefijos de alcance de variables A medida que aumenta el tamaño del proyecto, también aumenta la utilidad de reconocer rápidamente el alcance de las variables. Esto se consigue escribiendo un prefijo de alcance de una letra delante del prefijo de tipo, sin aumentar demasiado la longitud del nombre de las variables. Alcance Global Nivel de módulo Local del procedimiento Prefijo g m Ninguno Ejemplo gstrNombreUsuario mblnProgresoDelCálculo dblVelocidad Una variable tiene alcance global si se declara como Public en un módulo estándar o en un módulo de formulario. Una variable tiene alcance de nivel de módulo si se declara como Private en un módulo estándar o en un módulo de formulario, respectivamente. Nota La coherencia es crucial para usar esta técnica de forma productiva; el corrector de sintaxis de Visual Basic no interceptará las variables de nivel de módulo que comiencen con "p". Constantes El nombre de las constantes se debe escribir en mayúsculas y minúsculas, con la letra inicial de cada palabra en mayúsculas. Aunque las constantes estándar de Visual Basic no incluyen información de tipo de datos y el alcance, los prefijos como i, s, g y m pueden ser muy útiles para entender el valor y el alcance de una constante. Para los nombres de constantes, se deben seguir las mismas normas que para las variables. Ejemplo 24 MintMáxListaUsuario ' ' gstrNuevaLínea ' ' Límite de entradas máximas para la lista de usuarios (valor entero, local del módulo) Carácter de nueva línea (cadena, global de la aplicación) Variables Declarar todas las variables ahorra tiempo de programación porque reduce el número de errores debidos a nombres de variables errados (por ejemplo, aNombreUsuarioTmp frente a sNombreUsuarioTmp frente a sNombreUsuarioTemp). En la ficha Editor del cuadro de diálogo Opciones, active la opción Declaración de variables requerida. La instrucción Option Explicit requiere que declare todas las variables del programa de Visual Basic. Las variables deben llevar un prefijo para indicar su tipo de datos. Opcionalmente, y en especial para programas largos, el prefijo se puede ampliar para indicar el alcance de la variable. 24/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Tipos de datos de variables Use los siguientes prefijos para indicar el tipo de datos de una variable. Tipo de datos Boolean Byte Objeto Collection Currency Date (Time) Double Error Integer Long Object Single String Tipo definido por el usuario Variant Prefijo bln byt col cur dtm dbl err int lng obj sng str udt vnt Ejemplo blnEncontrado bytDatosImagen colWidgets curIngresos dtmInicio dblTolerancia errNúmDeOrden intCantidad lngDistancia objActivo sngMedia strNombreF udtEmpleado vntCheckSum Nombres descriptivos de variables y procedimientos El cuerpo de un nombre de variable o procedimiento se debe escribir en mayúsculas y minúsculas y debe tener la longitud necesaria para describir su funcionalidad. Además, los nombres de funciones deben empezar con un verbo, como IniciarNombreMatriz o CerrarDiálogo. Para nombres que se usen con frecuencia o para términos largos, se recomienda usar abreviaturas estándar para que los nombres tengan una longitud razonable. En general, los nombres de variables con más de 32 caracteres pueden ser difíciles de leer en pantallas VGA. Cuando se usen abreviaturas, hay que asegurarse de que sean coherentes en toda la aplicación. Alternar aleatoriamente entre Cnt y Contar dentro de un proyecto provoca una confusión innecesaria. Tipos definidos por el usuario En un proyecto grande con muchos tipos definidos por el usuario, suele ser útil dar a cada uno de estos tipos un prefijo de tres caracteres. Si estos prefijos comienzan con "u", será fácil reconocerlos cuando se esté trabajando con tipos definidos por el usuario. Por ejemplo, “ucli” se podría usar como prefijo para las variables de un tipo Cliente definido por el usuario. InfoTec Data S02 25/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Estructuras de Control ( De Decisión ) Las estructuras de control le permiten controlar el flujo de ejecución del programa. Tenemos dos tipos de estructuras de control: • • Estructuras de decisión Estructuras de bucle En esta sesión nos ocuparemos de las estructuras de decisión. Estas estructuras nos permiten dentro de los procedimientos probar condiciones y, dependiendo de los resultados, realizar diferentes operaciones. Entre las estructuras de decisión que acepta Visual Basic se incluyen las siguientes: • • • If...Then If...Then...Else Select Case If...Then Use la estructura If...Then se usa para ejecutar una o más instrucciones basadas en una condición. Puede utilizar la sintaxis de una línea o un bloque de varias líneas: Sintaxis • If condición Then Sentencias • If condición Then Sentencias End If Condición normalmente es una comparación, pero puede ser cualquier expresión que dé como resultado un valor numérico. Visual Basic interpreta este valor como True o False; un valor numérico cero es False y se considera True cualquier valor numérico distinto de cero. Si condición es True, Visual Basic ejecuta todas las instrucciones que siguen a la palabra clave Then. Puede utilizar la sintaxis de una línea o de varias líneas para ejecutar una sentencia basada en una condición, los ejemplos 25 y 26 son equivalente. Ejemplo 25 If cualquierFecha < Now Then cualquierFecha = Now Ejemplo 26 If cualquierFecha < Now Then cualquierFecha = Now End If Observe que el formato de una única línea de If...Then no utiliza la instrucción End If. Si desea ejecutar más de una línea de código cuando condición sea True, debe utilizar la sintaxis de bloque de varias líneas If...Then...End If. 26/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Ejemplo 27 If cualquierFecha < Now Then cualquierFecha = Now Timer1.Enabled = False End If ' Desactiva el control Timer. Ejemplo 28 If chkAlumnoUNI.Value=1 Then txtCosto = Format(txtCosto*0.70,”Fixed”) txtCódigo.Enabled = True End If If...Then...Else Utilice un bloque If...Then...Else para definir varios bloques de sentencias, uno de los cuales se ejecutará: Sintaxis If condición1 Then [bloque de sentencias 1] [ElseIf condición2 Then [bloque de sentencias 2]] ... [Else [bloque de sentencias n]] End If Visual Basic evalúa primero condición1. Si es False, Visual Basic procede a evaluar condición2 y así sucesivamente, hasta que encuentre una condición True. Cuando encuentra una condición True, Visual Basic ejecuta el bloque de instrucciones correspondientes y después ejecuta el código que sigue a End If. Opcionalmente, puede incluir un bloque de instrucciones Else, que Visual Basic ejecutará si ninguna de las condiciones es True. If...Then...ElseIf es un caso especial de If...Then...Else. Observe que puede tener cualquier número de cláusulas ElseIf o ninguna. Puede incluir una cláusula Else sin tener en cuenta si tiene o no cláusulas ElseIf. InfoTec Data S02 27/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Ejemplo 29 Por ejemplo, la aplicación podría realizar distintas acciones dependiendo del control en que se haya hecho clic de una matriz de controles de menú: Private Sub mnuEdit_Click (Index As Integer) If Index = 0 Then ' Comando Cortar CopyActiveControl ' Llama a procedimientos generales ClearActiveControl ElseIf Index = 1 Then ' Comando Copiar CopyActiveControl ElseIf Index = 2 Then ' Comando Borrar ClearActiveControl Else ' Comando Pegar PasteActiveControl End If End Sub Ejemplo 30 If ClaveUsuario = “CEPS” Then ‘ Permite al usuario entrar al sistema Else ‘ Mostrar un mensaje advirtiendo error en la clave End If Ejemplo 30 Private Sub DterminaCondición() if Val(txtPromedio) >=13 Then txtCondición = “Aprobado” ElseIf Val(txtPromedio) >= 10 Then txtCondición = “Asistente” Else txtCondición = “Desaprobado” End If End Sub Observe que siempre puede agregar más cláusulas ElseIf a la estructura If...Then. Sin embargo, esta sintaxis puede resultar tediosa de escribir cuando cada ElseIf compara la misma expresión con un valor distinto. Para estas situaciones, puede utilizar la estructura de decisión Select Case. 28/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Select Case Visual Basic proporciona la estructura Select Case como alternativa a If...Then...Else para ejecutar selectivamente un bloque de sentencias entre varios bloques. La sentencia Select Case ofrece posibilidades similares a la instrucción If...Then...Else, pero hace que el código sea más legible cuando hay varias opciones. La estructura Select Case funciona con una única expresión de prueba que se evalúa una vez solamente, al principio de la estructura. Visual Basic compara el resultado de esta expresión con los valores de cada Case de la estructura. Si hay una coincidencia, ejecuta el bloque de sentencias asociado a ese Case: Select Case expresión_prueba [Case lista_expresiones1 [bloque de sentencias 1]] [Case lista_expresiones2 [bloque de sentencias 2]] . . . [Case Else [bloque de sentencias n]] End Select Cada lista_expresiones es una lista de uno o más valores. Si hay más de un valor en una lista, se separan los valores con comas. Cada bloque de sentencias contiene cero o más instrucciones. Si más de un Case coincide con la expresión de prueba, sólo se ejecutará el bloque de instrucciones asociado con la primera coincidencia. Visual Basic ejecuta las instrucciones de la cláusula (opcional) Case Else si ningún valor de la lista de expresiones coincide con la expresión de prueba. Ejemplo 31 Por ejemplo, suponga que agrega otro comando al menú Edición (Ejemplo 29) en el ejemplo If...Then...Else. Podría agregar otra cláusula ElseIf o podría escribir el procedimiento con Select Case: Private Sub mnuEdit_Click (Index As Integer) Select Case Index Case 0 ' Comando Cortar CopyActiveControl ' Llama a procedimientos generales ClearActiveControl Case 1 ' Comando Copiar. CopyActiveControl Case 2 ' Comando Borrar. ClearActiveControl Case 3 ' Comando Pegar. PasteActiveControl Case Else frmFind.Show ' Muestra el cuadro de diálogo Buscar. End Select End Sub InfoTec Data S02 29/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Ejemplo 31 Select Case TipoUsuario Case “Supervisor” ‘ Proporciona al usuario privilegios de Supervisor Case “Usuario” ‘ Proporciona al usuario privilegios de Usuario Case Else ‘ Proporciona al usuario privilegios de invitado End Select Observe que la estructura Select Case evalúa una expresión cada vez al principio de la estructura. Por el contrario, la estructura If...Then...Else puede evaluar una expresión diferente en cada sentencia ElseIf. Sólo puede sustituir una estructura If...Then...Else con una estructura Select Case si la instrucción If y cada instrucción ElseIf evalúa la misma expresión. Otros Ejemplos Ejemplo 32 If Ventas > 100000 Then strDscto = Format(0.10,”Fixed”) ElseIf Ventas > 50000 Then strDscto = Format(0.05,”Fixed”) Else StrDscto = Format(0.02,”Fixed”) End If Ejemplo 32 Select Case Cantidad Case 1 sngDscto = 0.0 Case 2, 3 sngDscto = 0.05 Case 4 To 6 sngDscto = 0.10 Case Else sngDscto = 0.20 End Select 30/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M. Tipos de Datos, Variables, Constantes y Estructuras de Decisión Ejemplo 33 intRpta = MsgBox(“Guarda cambios antes de salir”,vbYesNo) Select Case intRpta Case vbYes GuardarCambios Unload Me Case vbNo Unload Me End Select Ejercicio 01 Desarrollar un formulario que permita ingresar tres números enteros, y que permita ordenarlos en forma ascendente o descendente. Ejercicio 02 En un centro de fotocopiado se realiza descuentos que dependen de la cantidad de copias, estos descuentos se rigen según la siguiente tabla, donde n representa el número de copias: Nro. De Copias N < 50 50 ≤ N < 100 100 ≤ N < 500 N ≥ 500 % de Descuento 0 5 7 10 Este porcentaje de descuento se aplica al monto total. Diseñe un formulario que permita al usuario ingresar el número de copias y que calcule: • • • El monto total (sin descuento) El descuento (si le corresponde) El monto neto (Aplicando el descuento) InfoTec Data S02 31/32 Fundamentos de Programación Visual (MS Visual Basic – Básico) Pagina en Blanco 32/32 S02 Eric G. Coronel Castillo & Sergio Matsukawa M.