Está en la página 1de 59

Arreglos Salvador Gurrola Velazquez salvador.gurrola@yahoo.com.

mx

Arreglos
Los Arreglos se utilizan para almacenar un conjunto de variables, que sean del mismo tipo de dato, y todas estas bajo un mismo nombre. Por ejemplo imaginemos que tenemos 20 variables de tipo String que almacenan nombres (nombre1, nombre2, etc..). si se quisiera pasar todas estas cadenas a minsculas tendra que utilizar la funcin Lcase con cada variable: nombre1 = Lcase(nombre1), nombre2 = Lcase(nombre2), etc.. En cambio si utilizara un arreglo la solucin seria:
Dim nombres(30) As String For x = 0 To 30 nombres(x) = LCase(nombres(x)) Next

Declaracin de los arreglos en el cdigo


Para crear un arreglo se debe en primer lugar declararlo como cualquier otra variable, la nica diferencia es que debemos indicar la cantidad de elementos que contendr el arreglo, colocando el nmero de ndice entre parntesis. Por ejemplo : Lo siguiente crea un arreglo de 15 elementos o datos de tipo integer

Dim miArreglo (1 to 15) as integer


Esto crea un arreglo de 11 elementos o datos de tipo String

Dim empleados (10) as String


El primer nmero , el 1 , indica el lmite inferior del mismo, y el nmero 15 indica el lmite mximo del arreglo, conformando de esta manera un arreglo que podr almacenar 15 datos de tipo string. En el segundo ejemplo, declaramos un arreglo de 11 elementos de tipo string. Como pods ver hemos indicado solo un nmero que representa el valor mximo del mismo. Cabe aclarar que hemos puesto de ndice el nmero 10, pero en realidad el arreglo contiene 11 elementos ya que cuando NO indicamos el limite inferior , se asume que el mismo comienza desde el 0.

Acceder a los datos de un arreglo


Para acceder a los datos de un arreglo o vector, debemos hacerlo mediante el ndice o nmero del elemento del mismo. Por ejemplo: Dim alumnos(1 To 4) As String

alumnos(1) = "juan" alumnos(2) = "micaela" alumnos(3) = "mara" alumnos(4) = "ignacio


Primero declaramos un arreglo llamado alumnos, de tipo string y que contendr 4 elementos. Luego le asignamos un valor de cadena como a cualquier otra variable de tipo string, pero con la diferencia que para referirnos al elemento utilizamos el n de ndice del mismo.

Acceder a los datos de un arreglo


Dim paises(2) As String ' Llena el vector con datos paises(0) = "Argentina" paises(1) = "Per" paises(2) = "Brasil" ' Recorre los elementos del vector For x = 0 To 2 MsgBox "Nombre del pas : " & paises(x) Next x En este ltimo ejemplo, declaramos y creamos un vector de 3 elementos que contendr el nombre de 3 pases. Luego en un bucle For utilizamos la funcin MsgBox para mostrar los elementos del arreglo, pasndole como parmetro del ndice la variable x del bucle For

Utilizar una estructura Type o UDT en un arreglo


Como vimos, en un arreglo podemos almacenar datos de cualquier tipo pero no mezclarlos, es decir podemos crear arreglos de tipo string, de tipo Integer etc,,, pero sin duda que lo mas importante y de mas utilidad a la hora de programar es la utilizacin de datos definidos por nosotros mediante una estructura Type Por ejemplo:
Option Explicit ' Estructura de dato para el vector Private Type agenda
nombre As String apellido As String cpostal As Integer

End Type ' Declaramos el vector Dim personas(1 To 3) As agenda

Utilizar una estructura Type o UDT en un arreglo


Private Sub Form_Load() ' Llenamos con datos para el elemento 1 del arreglo personas(1).nombre = "carlos" personas(1).apellido = "Martnez" personas(1).cpostal = 1900 ' Llenamos con datos para el elemento 2 del arreglo personas(2).nombre = "Hctor" personas(2).apellido = "rosales" personas(2).cpostal = 1898 ' Llenamos con datos para el elemento 3 del arreglo personas(3).nombre = "Albert" personas(3).apellido = "Einstein" personas(3).cpostal = 1324 End Sub

Las matrices
Como se dijo anteriormente, las matrices son arreglos de mas de 1 dimensin (2 o mas), a diferencia de los vectores que poseen una sola dimensin. Podemos imaginar una matriz bidimensional ( 2 dimensiones) , como una cuadrcula con filas y columnas, donde las filas representaran las coordenadas x y las columnas las coordenadas y. A una matriz de 3 dimensiones o tridimensional se la puede imaginar con las coordenadas x, y, z, y esta es ideal para representar figuras en el espacio por ejemplo. Las matrices se declaran en el cdigo de manera igual que los vectores, con la diferencia que debemos indicar mas subndices de acuerdo a la cantidad de dimensiones que posea la matriz. por lo general no se suele utilizar matrices de mas de 3 dimensiones..

Ejemplo de matriz de 2 dimensiones


Matriz bidimensionales de 6 x 8 (de 2 dimensiones). Dim personas (1 to 6, 1 to 8) as string Si luego quisiera acceder a los datos de la misma basta con referirnos a los subndices Por ejemplo: personas (1, 1) = "Natalia" personas (2, 1) = "pedro" personas (1, 7) = "valeria" personas (1, 8) = "jos" personas (2, 2) = "carolina" personas (4, 1) = "raquel" personas (6, 2) = "eustaquio" personas (6, 5) = "maria" personas (6, 8) = "mariana" El total de ndices posibles para almacenar datos o valores en el ejemplo anterior es de 48 datos, ya que si multiplicamos 6 x 8 nos da como total 48 valores posibles para utilizar en la matriz bidimensional.

Ejemplo de matriz de 2 dimensiones



En este ejemplo creamos una matriz de 3 dimensiones de 3 x 3 x 3 Dim cubo (1 to 3, 1 to 3, 1 to 3) as integer para acceder a los datos sera exactamente de la misma manera pero debemos utilizar un ndice mas.
Ejemplo: cubo (1, 1 , 1) = 50 cubo (1, 1 , 2) = 50 cubo (1, 1 , 3) = 50 cubo (1, 2 , 1) = 50 cubo (1, 2 , 2) = 50 cubo (1, 2 , 3) = 50 cubo (1, 3 , 1) = 50 cubo (1, 3 , 2) = 50 cubo (1, 3 , 3) = 50 cubo (2, 1 , 1) = 50 cubo (2, 1 , 2) = 50 cubo (2, 1 , 3) = 50 cubo (2, 2 , 1) = 50 cubo (2, 2 , 2) = 50 cubo (2, 2 , 3) = 50 cubo (2, 3 , 1) = 50 cubo (2, 3 , 2) = 50 cubo (2, 3 , 3) = 50 cubo (3, 1 , 1) = 50 cubo (3, 1 , 2) = 50 cubo (3, 1 , 3) = 50 cubo (3, 2 , 1) = 50 cubo (3, 2 , 2) = 50 cubo (3, 2 , 3) = 50 cubo (3, 3 , 1) = 50 cubo (3, 3 , 2) = 50 cubo (3, 3 , 3) = 50

En el ejemplo anterior, que es un poco extenso, es para que veas todos los posibles valores que puedes almacenar en una matriz de 3 x 3 x 3, y que da como resultado un arreglo de 27 valores posibles.

Vectores dinmicos
Hasta ahora habamos visto solo vectores o arreglos de tamao fijo, pero qu pasa cuando no sabemos el tamao o el largo de un vector y queremos que sea variable ?. Visual basic posee una sentencia o funcin que nos permite cambiar el largo de un vector en tiempo de ejecucin, dndonos as mas flexibilidad, y de esta manera no desperdiciar memoria y recursos de la pc creando vectores mas largos de lo que realmente necesitamos. Esta funcin se llama ReDim y ReDim Preserve

Ejemplo de vectores y arreglos dinmicos


En lo siguiente, primero declaramos un vector de la forma como lo hacemos siempre con la diferencia de que en vez de colocar un tamao declaramos el vector solo con los parntesis : Dim alumnos () as string Ahora le establecemos un tamao, por ejemplo de 4 elementos y le agregamos valores: ReDim alumnos(1 To 4) As String alumnos(1) = "Luciano" alumnos(2) = "Esteban" alumnos(3) = "Mariano" alumnos(4) = "Pedro"

Ejemplo de vectores y arreglos dinmicos


Ahora para redimensionar el tamao del vector por ejemplo a 7 elementos, utilizamos la funcin ReDim Preserve, para preservar los 4 valores anteriores y le agregamos 3 valores mas: ReDim Preserve alumnos(1 To 7) alumnos(5) = "Karina" alumnos(6) = "Ral" alumnos(7) = "Romina" Nota: si utilizamos la sentencia ReDim, o mejor dicho si redimensionamos el vector sin utilizar la sentencia ReDim preserve, los valores que contena el vector anteriormente se perdern

Eliminar o vaciar un vector


Para eliminar un array, arreglo o vector, podemos utilizar Erase, por ejemplo: Erase Nombre_Del_Vector

Funciones de VB para trabajar con Arreglos - LBound y UBound


Estas funciones son ideales para trabajar con vectores y matrices que han sido declaradas dinmicamente Lbound y Ubound nos devuelve un nmero de tipo Long que nos permite saber el lmite superior e inferior de un vector o una matriz.

Ejemplo de Ubound y Bound


Private Sub Form_Load() 'Variables Para almacenar los lmites superior e inferior Dim LimiteInferior As Long Dim LimiteSuperior As Long 'Declaramos 3 matrices, de una dimensin, _ de dos dimensiones y de 3 Dim UnVector(1 To 520) As Integer Dim UnaMatriz(20, 5 To 100) As String Dim OtraMatriz(10, 20, 30) As Long ' Devuelve 1 LimiteInferior = LBound(UnVector) ' Devuelve 520 LimiteSuperior = UBound(UnVector) ' Devuelve 0 LimiteInferior = LBound(UnaMatriz, 1) ' Devuelve 20 LimiteSuperior = UBound(UnaMatriz, 1) ' Devuelve 5 LimiteInferior = LBound(UnaMatriz, 2) ' Devuelve 100 LimiteSuperior = UBound(UnaMatriz, 2) ' Devuelve 0 LimiteInferior = LBound(OtraMatriz, 1) ' Devuelve 10 LimiteSuperior = UBound(OtraMatriz, 1) ' Devuelve 0 LimiteInferior = LBound(OtraMatriz, 2) ' Devuelve 20 LimiteSuperior = UBound(OtraMatriz, 2) ' Devuelve 0 LimiteInferior = LBound(OtraMatriz, 3) ' Devuelve 30 LimiteSuperior = UBound(OtraMatriz, 3) End Sub

Ejemplo 2 de LBound y UBound:


Si deseamos recorrer todos los elementos de un vector o una matriz podemos hacerlo mediante un bucle For de la siguiente manera:

For x = LBound(vector) To UBound(vector) MsgBox vector(x) Next i

Funcin Join
Esta funcin se utiliza para unir en una sola variable el conjunto de subcadenas de un vector. Esta funcin tiene solo 2 parmetros y es muy fcil de usar. Ejemplo: Dim micadena as string Dim vector(1 To 3) As String vector(1) = "Carlos" vector(2) = "Pedro" vector(3) = "Juan" Ahora ejecutando Join, la variable micadena pasara a valer "Carlos-PedroJuan" micadena = join (vector, "-") Nota: En el primer parmetro de la funcin debemos indicar el vector en el cual trabajar, y en el segundo se debe indicar un delimitador de caracter para separar las cadenas. Si no especificamos ninguno, visual basic utilizar por defecto un espacio vaco o en blanco (" ") para separar cada subcadena

Funcin Split:
Esta funcin hace el trabajo inverso de la funcin Join. Split se utiliza para rellenar un vector dinmico que contiene un nmero de subcadenas a partir de una cadena que le pasamos como parmetro a la funcin. Para aclarar un poco un ejemplo Private Sub Form_Load()
'Una variable para almacenar una cadena Dim Micadena As String 'Vector dinmico Dim Vector() As String 'Le damos un valor a la variable Micadena = "maria/natalia/romina" 'Ejecutamos la funcin Split Vector = Split(Micadena, "/") 'Ahora el vector dinmico pasara a _ contener los siguientes valores: Vector(0) = "mara" Vector(1) = "natalia" Vector(2) = "Romina"

End Sub Nota: una cosa importante es que en el vector anterior no se ha declarado un rango , ya que la funcin devuelve un vector cuya cantidad de elementos se ignora, es decir no se conoce.

Funcin Filter :
La funcin Filter se utiliza para filtrar subcadenas de un vector dependiendo de un determinado criterio de bsqueda. Los parmetros que lleva la funcin son los siguientes: Filter (vector donde buscar, cadena a buscar, valor booleano que indica si incluir o excluir la cadena) Ejemplo: ' Vector Dim Alumnos(1 To 4) As String ' Vector dinmico para almacenar el resultado Dim Resultado() As String Alumnos(1) = "Luciano" Alumnos(2) = "Lucas" Alumnos(3) = "juan" Alumnos(4) = "Natalia" ' Ejecutamos Filter Resultado = Filter(Alumnos, "Lu", True) ' Ahora el vector dinmico "resultado" pasa a contener MsgBox Resultado(0), vbInformation ' Luciano MsgBox Resultado(1), vbInformation ' Lucas

Funcin Filter :
La funcin Filter se utiliza para filtrar subcadenas de un vector dependiendo de un determinado criterio de bsqueda. Los parmetros que lleva la funcin son los siguientes: Filter (vector donde buscar, cadena a buscar, valor booleano que indica si incluir o excluir la cadena) Ejemplo: ' Vector Dim Alumnos(1 To 4) As String ' Vector dinmico para almacenar el resultado Dim Resultado() As String Alumnos(1) = "Luciano" Alumnos(2) = "Lucas" Alumnos(3) = "juan" Alumnos(4) = "Natalia" ' Ejecutamos Filter Resultado = Filter(Alumnos, "Lu", True) ' Ahora el vector dinmico "resultado" pasa a contener MsgBox Resultado(0), vbInformation ' Luciano MsgBox Resultado(1), vbInformation ' Lucas

Archivos

Archivos En esta seccin se ve un repaso bsico de las tres formas de trabajar con diferentes tipos de archivos en visual basic: Archivos secuenciales, archivos aleatorios y archivos binarios. Por ltimo en el final de la seccin, se describe como utilizar sentencias y funciones propias de visual basic para trabajar con archivos y directorios del sistema operativo, como por ejemplo la sentencia Dir para buscar ficheros, Filecopy para copiar , ChDir, Mkdir para crear carpetas y algunas otras funciones relacionadas.

Sentencia Open
Esta sentencia es la encargada de abrir o crear un archivo, ya sea para leer datos del mismo, sobre escribirlos y/o para agregarle datos. Esta sentencia tiene una serie de parmetros que varan de acuerdo a lo que queramos hacer. Por ejemplo : Open "c:\prueba.txt" For Input As #1 Este ejemplo abre un archivo para poder acceder a los datos que contenga en su interior. cuando decimos abrir, estamos diciendo que se encuentra actualmente abierto y alojado en la memoria ram para poder manipularlo. En el primer parmetro indicamos el path del archivo en el que queremos trabajar. Luego la palabra "As #1" indica el nmero de archivo que estamos utilizando. Este nmero lo asignamos nosotros y va desde el rango 1 al 511. El "nmero de archivo" se utiliza para poder diferenciar al archivo en el cdigo. Cada archivo que se encuentra abierto no se puede asignar un nmero de archivo igual, ya que nos dara un error en tiempo de ejecucin.

Sentencia Close
Una vez que terminamos de trabajar con un archivo que se encuentra abierto y que no lo vamos a utilizar mas, debemos cerrarlo. para ello se utiliza la sentencia Close seguido del nmero de archivo que lo identifica. Por ejemplo: Close #2 Esto cerrar al archivo abierto que anteriormente le asignamos el nmero de archivo 2. Tambin si tengo 3 archivos abiertos podra hacer lo siguiente: Close #1, #2, #3 Si utilizamos la sentencia Close sin ningn parmetro, o mejor dicho ningn nmero de archivo, se cerrarn todos los archivos cargados en memoria por nuestra aplicacin (los que nosotros abrimos con Open).

Sentencia Close
Por lo general, si trabajamos con varios archivos abiertos simultneamente, es aconsejable utilizar la sentencia Close sin ningn parmetro, de este modo cuando termine de ejecutarse el procedimiento se cerrarn todos los archivos abiertos. Hay una funcin en Visual basic llamada FreeFile. Esta funcin lo que hace es darnos un nmero de archivo que est libre y que se pueda usar, para que de este modo no intentamos abrir uno est siendo utilizado, y evitar un error en tiempo de ejecucin. Para usar la funcin es muy fcil, por ejemplo: Dim NumeroArchivo As Integer NumeroArchivo = FreeFile Open "La ruta de un archivo" For Input As #NumeroArchivo

Archivos secuenciales
Los archivos secuenciales se denominan de esta manera por que la forma de escribir y leer los datos en un archivo es, desde el principio hasta el fin del archivo, es decir, si yo quisiera acceder a un determinado dato del archivo y este dato se encuentra en la mitad del archivo, para llegar a ese dato necesito pasar por todos los dems datos, de forma secuencial. Por lo general se suelen utilizar los archivos secuenciales, para trabajar con archivos que contengan una estructura de datos no muy compleja. por que por ejemplo, si utilizramos un archivo para almacenar 50000 nombres con sus respectivos datos (apellido, telfono, direccin etc...) , este mecanismo resultara ineficiente, ya que si quisiera recuperar por ejemplo el registro n 3650, para leer este dato tendra que pasar previamente por los 3649 registros anteriores a este, haciendo mas lento el acceso y por lo tanto desperdiciando recursos del sistema.

Diferentes tipos de acceso


Append: esta sentencia se utiliza para agregar informacin a un archivo de texto. Ejemplo : Open "c:\miarchivo.txt" For Append As #1 Si el archivo ya contiene datos, se le agregarn al mismo al final del archivo, si no contena datos los agrega igual. Si el archivo no existe, lo crea y le agrega los datos. Input: la sentencia Input se utiliza para leer datos de un archivo de texto, ejemplo: Open "c:\miarchivo.txt" For Input As #2 Este ejemplo abre un archivo para leer los datos del mismo. En las prximas lneas veremos ejemplos de como leer los datos , escribir y guardar. Una cosa importante con respecto a leer datos de un archivo con Input es que, si el archivo que queremos abrir, no existe, se producir un error en tiempo de ejecucin al intentar abrir un archivo que no existe, por eso debemos verificar la ruta del mismo siempre que est bien escrita en la sentencia Open y evitarnos dolores de cabeza, y simpre aadir algn manejador de error para este caso

Diferentes tipos de acceso


Output: esta sentencia se utiliaza para crear un archivo de texto y grabar datos. Esta es igual que Append salvo por un gran detalle: Output crea el archivo y le agrega informacin, pero si el archivo exista y contena informacin previa, sobre escribe todos los datos del archivo por los datos nuevos, perdiendo los anteriores datos. Si accedemos con Output a un archivo que no existe, no se produce un error, si no que se crea dicho archivo. Conclusin : si vamos a aadir datos a un archivo existente (para actualizarlo por ejemplo) hay que utilizar la sentencia Append. si vamos a crear un archivo vaco y nuevo para grabar nuevos datos, hay que utilizar la sentencia Output. si vamos a abrir un archivo para leer datos utilizamos la sentencia Input.

Leer datos de un archivo utilizando Line Input


C omo se coment antes , para leer datos de un archivo se utiliza la sentencia Input. pero para leer los datos del archivo y poder utilizarlos en nuestro programa se utilizan 2 sentencias o instrucciones: Line Input e Input. Ejemplo: Dim mivariable As String

Open "c:\nombres.txt" For Input As #1 While Not EOF(1) Line Input #1, mivariable Wend Close #1

En el ejemplo anterior aparece una funcin nueva llamada EOF. Esta funcin significa End Of File o fin de archivo. Cuando abrimos un archivo para leer informacin con Input, debemos saber en que momento llegamos al final del archivo, por que de lo contrario la sentencia Line Input o Input seguira leyendo lneas donde no existen datos despus del fin del archivo, y por lo tanto se producira un error en tiempo de ejecucin por querer leer un dato que no existe.

Leer datos de un archivo utilizando Line Input


Mediante la condicin Not Eof(1) leeremos los datos hasta que llegue al final del archivo, y en cada pasada del bucle While se almacenar en la variable mivariable, lnea por lnea los datos del mismo. Es evidente que como est planteado el ejemplo habra que manipular los datos ledos y agregar otras instrucciones, por que en este ejemplo la variable mivariable solo almacenara los datos de la lnea que est leyendo y borrando los datos de las lneas que almacen anteriormente. Mas adelante veremos como solucionar esto. conclusin : para leer datos de un archivo se utiliza la sentencia Line Input y luego de la coma debemos poner una variable nuestra para almacenar los datos que se van leyendo de la lnea actual
Line Input #1, nuestravariable

Lo siguiente, lee un archivo de texto lnea por lnea, y carga el contenido en un control ListBox. colocar un control List1, un Command1 y un Text1 para indicar el path del archivo a leer:

Ejemplo para leer un archivo de texto utilizando Line Input

Option Explicit Private Sub Command1_Click() On Error GoTo errSub Dim n_File As Integer Dim Linea As String 'Elimina el contenido del listbox List1.Clear 'Nmero de archivo libre n_File = FreeFile 'Abre el archivo para leer los datos Open text1.Text For Input As n_File 'Recorre linea a linea el mismo y aade las lineas al control List Do While Not EOF(n_File) 'Lee la linea Line Input #n_File, Linea List1.AddItem Linea Loop Exit Sub errSub: 'error MsgBox "Nmero de error: " & Err.Number & vbNewLine & _ "Descripcin del error: " & Err.Description, vbCritical End Sub Private Sub Form_Load() Command1.Caption = " Cargar en Listbox " End Sub

Ejemplo para leer un archivo de texto utilizando Line Input


Este otro ejemplo, lo que hace es leer un archivo de texto para contar las lneas del mismo Colocar un command1 en el formulario y pegar el siguiente cdigo fuente
Public Function Contar_Lineas(ByVal strTextFile As String) As Long Dim F As Integer Dim Lineas As Long Dim str_Linea As String ' Nmero de archivo libre F = FreeFile ' Abre el archivo de texto Open strTextFile For Input As #F 'Recorre todo el archivo de texto _ linea por linea hasta el final Do 'Lee una lnea Line Input #F, str_Linea Incrementa la cantidad de lineas leidas Lineas = Lineas + 1 ' Leer hasta que llegue al fin de archivo Loop While Not EOF(F) ' Cierra el archivo de texto abierto Close #F ' Retorna a la funcin el nmero de lineas del fichero Contar_ Lineas = Lineas End Function Private Sub Command1_Click() Dim Path As String Path = InputBox(" Ingrese la ruta de un archivo de texto ", _ " Contar lneas ") If Path = vbNullString Then Exit Sub MsgBox " Cantidad de lineas: " & Contar_Lineas(Path) End Sub

La funcin input, a diferencia de Line Input que Lee por lnea, Input lee todo el contenido del archivo de una sola ves, es decir no necesitamos, como en el ejemplo anterior, utilizar un bucle. El modo de usarlo es el siguiente: Primero se abre el archivo con Open, por ejemplo: Open Path_Archivo For Input As #1 Luego se asigna a una variable, el contenido que devolver la funcin Input: Contenido = Input(LOF(1), #1)

Leer el contenido de un archivo de texto con la funcin Input

Lo siguiente lee el contenido de un archivo txt y lo carga en un textBox multilnea Colocar un TextBox llamado txt_Path ( para especificar la ruta del archivo ). El Textbox que mostrar los datos del fichero, colocarle el nombre txt_Contenido Cdigo en un botn:
On Error GoTo Err_Sub Dim n_File As Integer Dim Contenido As String 'Nmero de archivo libre n_File = FreeFile 'Abre el archivo indicado Open txt_Path For Input As n_File 'Lee todo los datos del archivo y lo almacena en la variable Contenido = Input$(LOF(n_File), #n_File) 'Cierra el archivo abierto Close n_File 'Carga el contenido de la variable en el TextBox txt_Contenido = Contenido Exit Sub Err_Sub: MsgBox Err.Description, vbCritical

Leer el contenido de un archivo de texto con la funcin Input

Escribir datos en archivos de texto


Para escribir datos en archivos de texto se utiliza la sentencia Print y Write. Ejemplo: Dim nombre As String Dim edad As Integer Dim telefono As String Open "c:\miarchivo.txt" For Append As #1 Print #1, "esta es una lnea" Print #1, "esta es otra lnea" Print #1, nombre, edad, telefono Close #1 En este ejemplo agregamos datos a un archivo existente llamado miArchivo.txt con la sentencia Print. Primero abrimos el archivo con Open. luego la sentencia Print lleva 2 parmetros. el primero indica el archivo que estamos manipulando (el archivo n1, dentro del cdigo), el segundo parmetro indica los datos que se agregarn en el mismo. En el segundo parmetro podemos poner un dato directamente (una cadena, nmero, etc...),, por ltimo cerramos el archivo.

Escribir datos con la sentencia Write


A diferencia de Print, la sentencia Write escribe datos en un archivo separados por comas. Ejemplo: Dim nombre As String Dim apellido As String apellido = "Peres" nombre = "Carlos" Open App.Path & "\Archivo.txt" For Output As #1 Write #1, nombre, apellido Close #1 Como podemos ver la sentencia Write escribe los datos en el archivo separados por coma. En la primera lnea escribir el contenido de las variables nombre y apellido .

Escribir datos con la sentencia Write


Tambin se pueden pasar los datos directamente a Write sin usar variables, por ejemplo: Write #1, "Un dato", "Otro dato", "Otro mas" Nota importante: cuando escribimos datos con la sentencia Print se utiliza la sentencia Line Input para leer los datos del archivo. En cambio cuando escribimos datos separados por comas con la sentencia Write debemos utilizar la sencia Input Para que esta pgina no sea tan extensa, he armado 10 ejercicios que utilizan todo lo visto hasta aqu, o sea el tema relacionado a los archivos secuenciales.

Archivos aleatorios o directos


A diferencia de los archivos secuenciales, los archivos aleatorios almacenan datos en forma de registros. Como habamos dicho en el captulo anterior para leer datos de un archivo secuencial haba que leer todo el archivo, es decir que no podamos leer por ejemplo los datos que estuviesen en la lnea 35 del mismo sin antes pasar por todos los datos anteriores, por eso su nombre de archivo secuencial. En cambio los archivos aleatorios, tambin llamados archivos directos, almacenan los datos con una estructura diferente. Los datos se guardan en registros mediante una estructura definida de tipo Type (estructura definida por nosotros) tambin llamada UDT Por ejemplo si tuviesemos 25 registros, cada uno con datos (apellido, email, telefono,etc..), y quisiera acceder al registro 17, puedo leer los datos del registro 17 sin tener que leer los 16 registros anteriores, ganando con ello mas velocidad y teniendo una estructura de datos definida. Para abrir un archivo aleatorio para trabajar con l, se utiliza la sentencia Open con algunos cambios en lo que se refiere a los archivos secuenciales

Archivos aleatorios o directos


Ejemplo: open "elarchivo.dat" for random as #1 len = len(mivariable) Como podemos ver para abrir un archivo de acceso aleatorio se utiliza la palabra Random (aleatorio). Luego debemos indicar el nmero de archivo para identificarlo, y por ltimo una opcin nueva : Len. cada registro en el archivo, que es una estructura de datos Type, tiene que tener una longitud fija. Mediante la funcin Len de visual Basic debemos indicar el tamao de la estructura de datos que vamos a utilizar.

Archivos aleatorios o directos


para que quede mas claro un ejemplo: Primero definimos una estructura de datos:
Private Type t_clientes nombre As String * 20 apellido As String * 15 direccin As String * 30 edad As Integer End Type

Despus creamos una variable llamada clientes de tipo t_clientes


Dim clientes As t_clientes

ahora abrimos nuestro archivo, y en el parmetro de la funcin Len le pasamos la variable para que visual basic calcule el tamao de la estructura t_clientes
Open "datos.dat" For Random As #1 Len = Len(clientes)

La estructura de datos debe tener un tamao fijo, no datos variables como en el caso de los archivos secuenciales, de ah que se indicara en el Type en las variables mediante el asterisco en el caso de los String.

Archivos aleatorios o directos


En cada campo de la estructura de datos debemos indicar el tamao de la variable. En el caso del campo nombre de tipo string le hemos asignado una longitud fija de 20 bytes, en el apellido 15 y en la direccin 30 bytes. La variable o el campo edad que es de tipo integer, no debemos indicar el tamao de la variable, ya que sabemos que un nmero integer ocupa 2 bytes. En total esta estructura t_clientes tiene una longitud de 67 bytes (30 + 20 + 15 + 2 ). Si no indicramos en la sentencia Open el tamao de la estructura, visual basic, por defecto asumira la estructura de un tamao de 128 bytes, y si nuestra estructura tendra mayor tamao ocurrira un error en tiempo de ejecucin, por lo cual siempre debemos utilizar la funcin len para calcular el tamao de la misma.

Grabar datos en archivos aleatorios


Para grabar datos en un archivo de acceso aleatorio se utiliza la sentencia Put. Un ejemplo paso a paso: primero declaramos una estructura de datos que contendr la informacin de cada registro:
Private Type t_empleados nombre As String * 15 apellido As String * 15 direccin As String * 30 edad As Integer End Type

Luego creamos una variable que sea de tipo t_empleados.


Dim empleados As t_empleados

Ahora abrimos el archivo e indicamos en la funcin Len el tamao de la estructura


Open "datos.dat" For Random As #1 Len = Len(clientes)

Grabar datos en archivos aleatorios


Ahora le asignamos un valor a cada campo de la estructura de esta forma:
empleados.nombre = "Carlos" empleados.apellido = "Martinez" empleados.direccin = "Avenida 9 de julio n 2054" empleados.edad = 45

Ahora grabamos en el registro n1 del archivo los datos de esta forma:


Put #1, 1, empleados

Si queremos grabar mas datos, por ejemplo en el registro n 2 del archivo hacemos lo siguiente:
empleados.nombre = "Mara" empleados.apellido = "Gonzales" empleados.direccin = "Avenida 13 n 1100" empleados.edad = 35 Put #1, 2, empleados Close #1

como vemos ver la sentencia Put lleva 3 parmetros. El primero indica el numero de archivo abierto en el cual estamos trabajando. en el segundo debemos indicar el nmero de registro en el que se grabarn los datos. Si no ponemos el nmero de registro, los datos se grabarn en el ltimo registro. Por ltimo en el tercer parmetro le pasamos la variable asociada con la estructura de datos.

Leer datos en archivos aleatorios


Para leer los registros o datos de un archivo aleatorio se utiliza la sentencia Get. Esta sentencia es exactamente igual que Put, pero la diferencia es que en vez de grabar los datos los recupera para poder utilizarlos luego en el programa.

Posicionarse en un registro determinado


Supongamos que tenemos un archivo aleatorio que contiene 452 registros. Ahora queremos recuperar los datos del registro 258. Para posicionarse en un determinado registro hay una sentencia , hay una sentencia llamada Seek. Ejemplo: Seek #1, 258 Get #1, , mivariable si queremos posicionarnos en un registro determinado, pero en vez de leer, queremos grabar datos, hacemos la misma operacin pero con la sentencia Put: Seek #1, 258 Put #1, , mivariable

Funcin Dir
La funcin Dir se utiliza o para buscar archivos y devuelve una cadena que representa el nombre de un archivo o directorio de acuerdo a un determinado patrn de bsqueda. La sintaxis de la funcin es: Dir (ruta, atributos) En el parmetro ruta debemos indicar el path de un archivo, directorio o unidad. Si el path no existe, la funcin Dir devuelve una cadena vaca. En el parmetro atributos podemos especificar los siguientes: vbnormal : cualquier atributo de archivo. vbreadonly : archivos de solo lectura. vbhidden: archivos ocultos vbsystem : archivos de sistema vbvolume : etiqueta de volumen de una unidad vbdirectory : directorios

Funcin Dir
Ejemplo: Si el archivo existe Dir devuelve "autoexec.bat" Archivoabuscar = Dir("c:\autoexec.bat") Tambin podemos utilizar los comodines * y ? para filtrar bsquedas. En este ejemplo devuelve el primer archivo exe que encuentra, si es que existe. Archivoabuscar = Dir("c:\windows\*.exe") En este ejemplo la funcin Dir devuelve directorios adems de archivos Archivoabuscar = Dir("c:\, vbdirectory") El nico inconveniente de esta funcin es que siempre devuelve el primer archivo que encuentra. Para que contine buscando los dems archivos debemos poner la funcin sin parmetros. Ejemplo Dim archivo As String archivo = Dir("c:\*.exe") While archivo <> "" archivo = Dir Wend En el ejemplo anterior buscar todos los archivos exe en el directorio c:\. cuando ya no encuentre mas devolver una cadena vaca y saldr del bucle While.

Funcin Dir
Este otro ejemplo verifica si un archivo existe: Private Function Verificar_Existe(path) As Boolean If Len(Trim$(Dir$(path))) Then Verificar_Existe = True Else Verificar_Existe = False End If MsgBox Verificar_Existe End Function Private Sub Form_Load() Call Verificar_Existe("c:\autoexec.bat") End Sub

Funcin FileCopy
FileCopy nos permite copiar archivos. Esta funcin es muy fcil de usar. ejemplo: FileCopy "origen", "destino" Nota: si el archivo existe la funcin lo sobre escribe.

Funcin MkDir
Esta funcin se utiliza para crear directorios, pero crea un directorio por vez, es decir que no crea varios niveles al mismo tiempo. La sintaxis es: MkDir "Ruta directorio" para poder crear un Directorio que contiene varios subdirectorios, podemos hacer lo siguiente: El ejemplo despliega un InputBox para ingresar el path a crear:

Funcin MkDir
Private Sub Command1_Click() Dim i As Integer Dim Array_Dir As Variant Dim Sub_Dir As String Dim El_Path As String El_Path = InputBox("Escriba la ruta del directorio a crear" & _ "con los subdirectorios", " Crear varios niveles de directorios") If El_Path = vbNullString Then Exit Sub 'Desglosa el path Array_Dir = Split(El_Path, "\") El_Path = vbNullString 'Recorre el array anterior para ir creando uno por uno For i = LBound(Array_Dir) To UBound(Array_Dir) Sub_Dir = Array_Dir(i) If Len(Sub_Dir) > 0 Then El_Path = El_Path & Sub_Dir & "\" If Right$(Sub_Dir, 1) <> ":" Then ' Verificamos que no exista If Dir$(El_Path, vbDirectory) = vbNullString Then 'Crea la carpeta Call MkDir(El_Path) End If End If End If Next i End Sub

Funcin kill
La funcin kill se utiliza para eliminar archivos. Tambin es muy fcil de utilizar, y el nico parmetro que lleva es la ruta del archivo que queremos eliminar. Si queremos eliminar varios archivos de un directorio podemos utilizar el comodn"*", y si queremos excluir ciertos archivos utilizamos el comodn "?".

kill "c:\*.txt"

Funcin FileLen
Esta funcin nos devuelve el tamao en bytes de un archivo. Ejemplo: Dim tamao As Long

tamao = FileLen("c:\windows\system32\control.exe")
MsgBox tamao & " bytes" FileLen es muy til para trabajar con archivos aleatorios, ya que si queremos conocer la cantidad de registros que tiene el archivo, debemos dividir el tamao del archivo por el tamao de la estructura.

Funcin FileLen
Ejemplo: Private Type t_personas nombre As String * 20 apellido As String * 20 End Type

Dim cant_reg As Long


Private Sub Form_Load()

cant_reg = FileLen("c:\miarchivo.dat") / Len(t_personas)


End Sub

Funcin Name
Name se utiliza para renombrar archivos y directorios. Esta funcin no se puede utilizar para renombrar archivos abiertos. Ejemplo: Name "path del archivo viejo a renombrar" as "path y nombre nuevo del archivo" Tambin con esta sentencia podemos mover archivos y directorios a otra ubicacin. para ello debemos cambiar en el segundo parmetro la ruta del archivo.

Funcin GetAttr y SetAttr


La funcin Getattr permite recuperar informacin sobre los atributos de un archivo o directorio. Ejemplo:

GetAttr "ruta del archivo"


los valores devueltos por la funcin pueden ser los siguientes: 0 - normal 1 - solo lectura 2 - oculto 4 - archivo de sistema 16 - directorio 32 - archivo modificado

Funcin GetAttr y SetAttr


El siguiente ejemplo lo que hace es mostrar en un MsgBox los atributos de un archivo. Colocar un TextBox llamado Text1 y un Command1. Cdigo en el formulario: Option Explicit Private Sub Command1_Click() Dim ret As Long Dim Atributos As String ret = GetAttr(Text1.Text) If ret And vbNormal Then Atributos = " Normal = Si" & vbNewLine Else Atributos = " Normal = No" & vbNewLine End If If ret And vbReadOnly Then Atributos = Atributos & " Solo Lectura = Si" & vbNewLine Else Atributos = Atributos & " Solo Lectura = No" & vbNewLine End If If ret And vbHidden Then Atributos = Atributos & " Oculto = Si" & vbNewLine Else Atributos = Atributos & " Oculto = No" & vbNewLine End If If ret And vbSystem Then Atributos = Atributos & " Sitema = Si" & vbNewLine Else Atributos = Atributos & " Sitema = No" & vbNewLine End If If ret And vbDirectory Then Atributos = Atributos & " Directorio = Si" & vbNewLine Else Atributos = Atributos & " Directorio = No" & vbNewLine End If 'Muestra los atributos del archivo elegido MsgBox Atributos, vbInformation, " Atributos " End Sub

Funcin RmDir
RmDir elimina directorios o carpetas. Pero antes de eliminar directorios tenemos que estar seguros que la carpeta no contiene archivos, de lo contrario nos dar un error en tiempo de ejecucin. Si el directorio contiene archivos debemos eliminarlos previamente con la sentencia kill. Ejemplo: RmDir "path del directorio a remover"

También podría gustarte