Funciones y sentencias

18
FUNCIONES PARA…

Transcript of Funciones y sentencias

FUNCIONES PARA…

FUNCIÓNES LCASE Y UCASE

• Estas dos funciones se utilizan para convertir cadenas de texto a minúscula y mayúscula.La función Lcase cambia o convierte una cadena de texto a minúscula y un ejemplo de como utilizarla sería así:

• Lcase (cadena que queremos convertir a minúsculas)

•  

• Ejemplo:

Dim cadena As String

cadena = "HOLA MUNDO" ‘Convertimos cadena = LCase(cadena)

'La variable cadena ahora vale "hola mundo“

 

• La función Ucase funciona de la misma manera que Lcase pero convierte el contenido de una cadena a mayúsculas.

• Por ejemplo, si tenemos un control Label1 que contiene un texto que dice: "Porcentaje de sueldos", escribiendo la siguiente línea:

Label1 = UCase(Label1) 

El control Label1 pasaría a mostrar o mejor dicho contener en su propiedad caption:"PORCENTAJE DE SUELDOS".

FUNCIÓNES TRIM, LTRIM Y RTRIM

• Estas tres funciones se utilizan para eliminar los espacios vacíos de una cadena. 

• LTrim elimina los espacios vacíos de la parte izquierda de la cadena, RTrim de la parte derecha y Trim de ambas partes.

• Ejemplos:

Tenemos una variable llamada ciudad con el valor " Barcelona". Para eliminar los espacios vacíos de la izquierda haríamos lo siguiente:

ciudad = LTrim(ciudad) 

Si en un TextBox quisieramos borrar todos los espacios vacíos de la parte derecha de la cadena:

MiText = RTrim(MiText)

 

• La Función Trim elimina todos los espacios vacíos de ambos lados de la cadena.

• Ejemplo:

Pais = "     Argentina     " País = Trim(Pais)Ahora el valor de País es igual a: "Argentina".

FUNCIÓN LEN

• La función Len nos permite conocer la cantidad de caracteres que tiene una determinada cadena. O sea que esta función nos devuelve un número.

• Ejemplo:

Len (Aquí va la cadena que queremos averiguar su tamaño) 

Como la función Len devuelve un número debemos asignar ese número devuelto en una variable de tipo numérica.

• Ejemplo:

Dim TamanoCadena As Long

Dim MiCadena As String

MiCadena = "Me Llamo Eustaquio"

TamanoCadena = Len(MiCadena) 

• El valor de la variable TamanoCadena pasaría a valer 18.

• Hay que tener en cuenta que la función Len también toma en cuenta los espacios vacíos.

FUNCIÓNES ASC Y CHR

• La función Asc nos permite obtener el código ASCII de un de terminado caracter.

• Ejempos:

Si queremos obtener el código ASCII del caracter "a", que es el número 97 podríamos hacer lo siguiente:

Dim num As Integer  num = Asc("a")

• En definitiva la función Asc lleva un solo parámetro de tipo String del cual queremos obtener dicho número.

• La Función Chr actúa a la inversa de la función Asc, esto quiere decir, que a partir de un determinado número nos devolverá el caracter ASCII.

• Obviamente que en vez de pasarle a la función un parámetro String es decir la letra, debemos pasarle un número ASCII y nos devolverá el carácter asociado.

• Ejemplo:

Dim letra As String

letra = Chr(97)

• La variable pasa a valer en este caso el caracter "a"

FUNCIÓN INSTR

• La función InStr se utiliza para buscar una cadena o parte de una cadena dentro de otra cadena.

• Si la función encuentra la cadena a buscar devuelve un número que representa la posición donde encontró la cadena, si no la encuentra devuelve un 0.

• Los parámetros que lleva esta función son:

• InStr (comienzo, Cadena donde buscar , La Cadena a buscar)

• Como esta función devuelve un número debemos almacenarla en una variable de tipo numérica para utilizarla.

• Ejemplo:

Dim posicion As Integer

posicion = InStr("Estoy tomando mate", "mate")

• En este ejemplo la función encontró la cadena "mate" en la posición 15, o sea que la variable posición pasa a valer 15.

• Si observamos bien, la función en el primer parámetro, denominado comienzo, nos pide que le digamos desde que posición comenzar a buscar. En nuestro ejemplo, este parámetro lo obviamos, esto quiere decir que comenzará desde la posición 0 de la cadena a buscar. Pero podríamos especificar una posición en particular, por ejemplo desde la 5 , 10 etc..., según lo que necesitemos hacer.

FUNCIÓNES LEFT Y RIGHT

• Estas funciones son utilizadas para extraer partes de una cadena.

• La función Left:

• tiene 2 parámetros: El primero es la cadena de la cual se extraerán caracteres, y el segundo un número desde el cual comenzar a extraer caracteres desde la parte izquierda.

• Ejemplo:

Dim Cadena As String

Cadena = Left("Ya es la madrugada", 9)

'Cadena, que es un string, sería igual a: "Ya es la"

 

• Función Right:

• Es igual que la función Left pero comienza a extraer caracteres desde el lado derecho de la cadena.

•  

FUNCIÓN MID

• La función Mid:

• Tiene la misma función que las anteriores pero posee tres parámetros. Su sintaxis es:

• Mid (cadena, inicio, longitud)

• El parámetro cadena es la cadena a extraer caracteres. El parámetro Inicio es donde comenzar y el parámetro longitud, es la cantidad de caracteres a extraer de la cadena de caracteres

• Ejemplos:

Dim nombre As String nombre = Mid("River perdió la copa", 7, 6)

'La variable nombre sería igual a: "perdió"

FUNCIÓN INPUTBOX:

• La función InputBox presenta un mensaje al usuario, permitiéndole ingresar un valor en una caja de texto:

• Como se dijo la función InputBox presenta un cuadro de diálogo donde el usuario puede ingresar un texto y luego aceptar o cancelar dicho cuadro de diálogo.

• Los parámetros principales de esta función son:

• InputBox (Promt,Title, Default)

SENTENCIAS DE CONTROL

SENTENCIA IF … THEN … ELSE …

• Esta estructura permite ejecutar condicionalmente una o más sentencias y puede escribirse de dosformas. La primera ocupa sólo una línea y tiene la forma siguiente:

• If condicion Then sentencia1 [Else sentencia2]

• La segunda es más general y se muestra a continuación:

• If condicion Thensentencia(s)[Elsesentencia(s)]End If

• Si condicion es True (verdadera), se ejecutan las sentencias que están a continuación de Then, y sicondicion es False (falsa), se ejecutan las sentencias que están a continuación de Else, si estacláusula ha sido especificada (pues es opcional). Para indicar que se quiere ejecutar uno de variosbloques de sentencias dependientes cada uno de ellos de una condición, la estructuraadecuada es la siguiente:

• If condicion1 Thensentencias1ElseIf condicion2 Thensentencias2Elsesentencia-nEnd If

• Si se cumple la condicion1 se ejecutan las sentencias1, y si no se cumple, se examinansecuencialmente las condiciones siguientes hasta Else, ejecutándose las sentencias correspondientesal primer ElseIf cuya condición se cumpla. Si todas las condiciones son falsas, se ejecutan lassentencias-n correspondientes a Else, que es la opción por defecto.

SENTENCIA SELECT CASE

• Esta sentencia permite ejecutar una de entre varias acciones en función del valor de una expresión.Es una alternativa a If … Then … ElseIf cuando se compara la misma expresión con diferentesvalores. Su forma general es la siguiente:

• Select Case expresionCase etiq1[sentencias1]Case etiq2[sentencias2]Case ElsesentenciasnEnd Select

• donde expresion es una expresión numérica o alfanumérica, y etiq1, etiq2, … pueden adoptar lasformas siguientes:

• 1. expresion

• 2. expresion To expresion

• 3. Is operador-de-relación expresion

• 4. combinación de las anteriores separadas por comas

• Por ejemplo,

• Numero = 8 ’ Se inicializan las variable.Select Case Numero ’ Se va a evaluar la variable Numero.Case 1 To 5 ‘ Numero está entre 1 y 5.Resultado = “Se encuentra entre 1 y 5″‘ Lo siguiente se ejecuta si es True la expresión.Case 6, 7, 8 ‘ Numero es uno de los tres valores.Resultado = “Se encuentra entre 6 y 8″

• Case Is = 9 , Is = 10 ‘ Numero es 9 ó 10.

• Resultado = “El valor es 9 o 10″Case Else ‘ Resto de valores.Resultado = “El número no se encuentra entre 1 y 10″End Select

• Cuando se utiliza la forma expresion To expresion, el valor más pequeño debe aparecer en primerlugar.

• Cuando se ejecuta una sentencia Select Case, Visual Basic evalúa la expresion y el control delprograma se transfiere a la sentencia cuya etiqueta tenga el mismo valor que la expresión evaluada,ejecutando a continuación el correspondiente bloque de sentencias. Si no existe un valor igual a laexpresion entonces se ejecutan las sentencias a continuación de Case Else.

SENTENCIA FOR … NEXT

• La sentencia For da lugar a un lazo o bucle, y permite ejecutar un conjunto de sentencias ciertonúmero de veces. Su forma general es:

• For variable = expresion1 To expresion2 [Step expresion3] [sentencias]Exit For[sentencias]Next [variable]

• Cuando se ejecuta una sentencia For, primero se asigna el valor de la expresion1 a la variable y secomprueba si su valor es mayor o menor que la expresion2. En caso de ser menor se ejecutan lassentencias, y en caso de ser mayor el control del programa salta a las líneas a continuación deNext. Todo esto sucede en caso de ser la expresion3 positiva. En caso contrario se ejecutarán lassentencias cuando la variable sea mayor que expresion2. Una vez ejecutadas las sentencias, lavariable se incrementa en el valor de la expresion3, o en 1 si Step no se especifica, volviéndose aefectuar la comparación entre la variable y la expresion2, y así sucesivamente.

SENTENCIA DO … LOOP

• Un Loop (bucle) repite la ejecución de un conjunto de sentencias mientras una condición dada seacierta, o hasta que una condición dada sea cierta. La condición puede ser verificada antes odespués de ejecutarse el conjunto de sentencias. Sus posibles formas son las siguientes:

• ’ Formato 1:Do [{While/Until} condicion][sentencias] [Exit Do] [sentencias]Loop’ Formato 2:Do[sentencias] [Exit Do] [sentencias]Loop [{While/Until}condicion]La sentencia opcional Exit Do permite salir de una bucle Do … Loop antes de que finaliceéste. Por ejemplo,

• Check = True ’ Se inicializan las variables. Counts = 0Do ‘ Empieza sin comprobar ninguna condición.Do While Counts < 20 ‘ Bucle que acaba si Counts>=20 o con Exit Do.Counts = Counts + 1 ‘ Se incrementa Counts.If Counts = 10 Then ‘ Si Counts es 10.Check = False ‘ Se asigna a Check el valor False.Exit Do ‘ Se acaba el segundo Do.End IfLoopLoop Until Check = False ‘ Salir del “loop” si Check es False.

• En el ejemplo mostrado, se sale de los bucles siempre con Counts = 10. Es necesario fijarse que sise inicializa Counts con un número mayor o igual a 10 se entraría en un bucle infinito (el primerbucle acabaría con Counts = 20 pero el segundo no finalizaría nunca, bloqueándose el programa y aveces el ordenador).

SENTENCIA WHILE … WEND

• Esta sentencia es otra forma de generar bucles que se recorren mientras se cumpla la condicióninicial. Su estructura es la siguiente:While condicion[sentencias]Wend

• Por ejemplo,

• Counts = 0 ’ Se inicializa la variable.While Counts < 20 ’ Se comprueba el valor de Counts.Counts = Counts + 1 ’ Se incrementa el valor de Counts.Wend ’ Se acaba el bucle cuando Counts > 19.

• En cualquier caso se recuerda que la mejor forma de mirar y aprender el funcionamiento de todasestas sentencias es mediante el uso del Help de Visual Basic. Ofrece una explicación de cadacomando con ejemplos de utilización.

SENTENCIA FOR EACH … NEXT

• Esta construcción es similar al bucle For, con la diferencia de que la variable que controla larepetición del bucle no toma valores entre un mínimo y un máximo, sino a partir de los elementos deun array (o de una colección de objetos). La forma general es la siguiente:For Each variable In grupo[sentencias]Next variableCon arrays variable tiene que ser de tipo Variant. Con colecciones variable puede ser Varianto una variable de tipo Object. Esta construcción es muy útil cuando no se sabe el número deelementos que tiene el array o la colección de objetos.