Saltar al contenido
View in the app

A better way to browse. Learn more.

Ayuda Excel

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

VBA: dudas objeto Connection

publicado

Hola,

Mi nivel de programacion en VBA es medio-bajo.

Aunque no soy ajeno al mundillo de la programacion quisiera realizar una consulta a los foreros.

Pongamos el siguiente ejemplo. Desde una hoja Excel quiero importar datos externos (en este caso una hoja excel). Lo que yo hago normalmente es poner a grabar una macro, simulo la importacion de los datos y despues paro la macro. Asi obtengo el "esqueleto" del codigo y a partir de ahi lo modifico hasta conseguir exactamente lo que necesito.

Mi duda esta en esta parte del codigo (he recortado algunas cadenas de texto porque son irrelevantes)

With ActiveSheet.QueryTables.Add(Connection:=Array( _

"OLEDB;Provider=Microsoft.Jet.OLEDB.4.0;Password="""";User ID=Admin;Data Source=C:\Informes" _

, _

".xls;Mode=Share Deny Write;Extended Properties=""HDR=YES;"";Jet OLEDB:System database="""";Jet OLEDB:Registry Path=" _

, _

""""";Jet OLEDB:Database Password="""";Jet OLEDB:Engine Type=35;Jet OLEDB:Database Locking Mode=0;Jet OLEDB:Global Partial Bulk Ops=2" _

, _

";Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password="""";Jet OLEDB:Create System Database=False;Jet OLEDB:Encryp" _

, _

"t Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False" _

, ""), Destination:=Range("A1"))

.CommandType = xlCmdTable

.CommandText = Array("Informe_Hoja_1$")

.Name = "Informes"

.FieldNames = True

.RowNumbers = False

.FillAdjacentFormulas = False

.PreserveFormatting = True

.RefreshOnFileOpen = False

.BackgroundQuery = True

.RefreshStyle = xlInsertDeleteCells

.SavePassword = False

.SaveData = True

.AdjustColumnWidth = True

.RefreshPeriod = 0

.PreserveColumnInfo = True

.SourceDataFile = _

"C:\Informes.xls"

.Refresh BackgroundQuery:=False

End With

El Array que esta asignado al objeto Connection ¿cuantos elementos (separados por comas) ha de tener? ¿Es un numero predeterminado?

Quiero igualar Data Source a una cadena de texto obtenida por otros medios y he comprobado que ese Array modificado debe respetar el mismo numero de elementos originales separados por comas, en caso contrario no me funciona el codigo

Es decir, el codigo modificado quedaria asi segun entiendo yo:

With ActiveSheet.QueryTables.Add(Connection:=Array( _

"OLEDB;Provider=Microsoft.Jet.OLEDB.4.0;Password="""";User ID=Admin;Data Source=" & mi_cadena_de_texto _

, _

";Mode=Share Deny Write;Extended Properties=""HDR=YES;"";Jet OLEDB:System database="""";Jet OLEDB:Registry Path=" _

, _

""""";Jet OLEDB:Database Password="""";Jet OLEDB:Engine Type=35;Jet OLEDB:Database Locking Mode=0;Jet OLEDB:Global Partial Bulk Ops=2" _

, _

";Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password="""";Jet OLEDB:Create System Database=False;Jet OLEDB:Encryp" _

, _

"t Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False" _

, ""), Destination:=Range("A1"))

...

etc

...

End With

Gracias de antemano, un saludo

Featured Replies

publicado

Hola:

Si usas mucho conexiones, se que a través de la grabadora de macros probablemente se te facilita todo pero el uso de 'Query' puede ser superado a través por ejemplo del uso de ADO.

Ya yendo al debate puntual, debe quedar algo así:

...Data Source=") & mi_cadena_de_texto _ & (";Mode=Share Deny...

Sobre el limite de los Array en VBA, dale una leidita a esto:

XL: Limitations of Passing Arrays to Excel Using Automation

Abraham

PD: Conecction no es objeto :)

Archivado

Este tema está ahora archivado y está cerrado a más respuestas.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.