Saltar al contenido
PROGRAMAR EN VBA MACROS DE EXCEL

Como leer un archivo TXT separado coma con macro


.

En un ejemplo anterior se presentó una macro que lee archivos TXT, en el presente post muestro una macro que permite leer archivos TXT pero delimitados o separados por coma o punto y coma; es decir los datos que se encuentran en el archivo de texto plano, se encuentran separados por coma o punto y coma.

Antes de seguir recomiendo leer un excelente libro sobre Excel que te ayudará operar las planillas u hojas de cálculo, haz click acá, si quieres aprender sobre Excel, en inglés, entonces debes hacer click here. Si lo que necesitas es aprender o profundizar sobre la programación de macros con VBA este es unos de los mejores cursos on line que he visto en internet.

  
El link que se encuentra al final de post permite descargar el ejemplo de macro denominada como leer un archivo TXT separado o delimitado por coma o punto y coma; consiste en un archivo comprimido conteniendo dos archivos uno de Excel con la macro y otro archivo TXT que se usa para mostrar el funcionamiento del ejemplo, pero se puede usar cualquier archivo que tenga cada lector en su PC cuyos datos se encuentren delimitados o separados por coma.

El ejemplo agrega en la variable cada una de las cadenas de texto, a través de la función de VBA Split; cuya separación entre datos este dada por punto y coma, en este caso, pero se puede ser coma, para ello se debe cambiar la siguiente parte del código:

texto = Split(cad, «;»)

por este código:

texto = Split(cad, «,»)

Luego se realiza un bucle hasta que se llegue al final de todas las lineas del archivo TXT; por cada una de las cadenas de texto separadas por punto y coma, que fueran cargadas en la variable texto a través de la función Split, las cuales se van agregando en las diferentes columnas de la hoja de Excel.

El vídeo que sigue muestra una explicación más detallada y gráfica de la macro presentada, recomiendo observar para una más fácil comprensión de la macro; suscribe a nuestra web desde la parte superior derecha de la página ingresando tu mail y a nuestro canal de You Tube para recibir en tu correo vídeos explicativos sobre macros interesantes, como  por ejemplo formulario que crea un listado de todas las hojas para poder luego seleccionarlasbuscar en listbox mientras escribes en textboxordenar hojas libro excel por su nombreconectar Excel con Access y muchos ejemplos más.


if (payload.eventType == ‘subscribe’) {
// Add code to handle subscribe event.
} else if (payload.eventType == ‘unsubscribe’) {
// Add code to handle unsubscribe event.
}
if (window.console) { // for debugging only
window.console.log(‘YT event: ‘, payload);
}
}

 

Código que se inserta en un módulo
Sub opentxtseparadoscoma()
Application.ScreenUpdating = False
Application.DisplayAlerts = False
On Error Resume Next
Dim myfile As Variant, cad As String, fila As Long, texto() As String
Dim h As Long, fil As Long, col As Long
ruta = ActiveWorkbook.Path
ChDir ruta
myfile = Application.GetOpenFilename(«Archivos Txt (*.txt*), *.txt*»)
If VarType(myfile) = vbBoolean Then Exit Sub
Open myfile For Input As #1
fil = 1
col = 1
Cells.Clear
While Not EOF(1)
Line Input #1, cad
texto = Split(cad, «;»)
For h = 0 To UBound(texto)
Cells(fil, col) = fil
Cells(fil, col).Value = texto(h)
col = col + 1
Next h
col = 1
fil = fil + 1
Wend
Close #1
MsgBox («Los datos se leyeron con éxito»), vbInformation, «AVISO»
Application.ScreenUpdating = True
Application.DisplayAlerts = True
End Sub

Si te fue de utilidad puedes INVITARME UN CAFÉ y de esta manera ayudar a seguir manteniendo la página, CLICK para descargar en ejemplo en forma gratuita.


.

If this post was helpful INVITE ME A COFFEE and so help keep up the page, CLICK to download free example.

Si te gustó por favor compártelo con tus amigos
If you liked please share it with your friends