Truco Excel. Pasar un rango de varias columnas a una

Macro de Excel que nos permite pasar de varias columnas a una sola. De momento no es una función, es un código que sorprende por su sencillez:

Sub rango_columnas()

Dim rango As Variant
Dim i As Long, j As Long, k As Long
Dim col As Long

rango = Selection.Value

'Esta es la parte que permite ubicar la salida
col = Selection.Column
k = Selection.Row

'Esto recorre el rango y realiza la trasposición
For i = 1 To UBound(rango, 1)
    For j = 1 To UBound(rango, 2)
        Cells(k, col + UBound(rango, 2)).Value = rango(i, j)
        k = k + 1
    Next
Next

End Sub

Este código lo ponéis tal cual en vuestro Excel y os ilustro a continuación sobre su funcionamiento. Lo primero es seleccionar el rango de columnas que deseamos transponer:

varias_columnas_a_una_excel1

Ahora sólo ejecutamos la macro rango_columnas:

varias_columnas_a_una_excel2

Y aparece justo al lado del rango que deseamos transponer a una sola columna:

varias_columnas_a_una_excel3

En este caso el resultado lo obtenemos en la columna F. Jugando con los índices i y j de nuestra macro podremos modificar la forma de la transposición. Me parece una macro útil y por eso lo comparto con vosotros. Saludos.

21 comentarios en “Truco Excel. Pasar un rango de varias columnas a una

  1. ¡Excelente! Me salvaste, acababa de organizar unas combinaciones con 11.675 celdas y necesitaba convertirlas a una sola columna para subir las palabras clave de una campaña de Google Adwords. Igualmente estoy asombrada no solamente por lo sencillo del código (16 líneas incluyendo comentarios) sino también por la rapidez en generar el resultado (quedé así como “¿OMG ya terminó?”). Nuevamente, ¡muchas gracias!

  2. Funciona de Maravilla la Macro, pero tengo otro caso…. donde las columnas son de diferente tamaño de información…y al efectuar la Macro me deja espacios Vacios… Me podrias ayudar para que no contemplara esos espacios…. te lo agradecere mucho

    1. Sub unir_columnas()
      ‘Por.DAM
      ci = Columns(“C”).Column ‘columna inicial a unir
      cf = Columns(“O”).Column ‘columna final a unir
      cd = Columns(“Z”).Column ‘columna unión
      f = 1 ‘fila inicial de datos
      For i = ci To cf
      uf = Cells(Rows.Count, i).End(xlUp).Row
      ud = Cells(Rows.Count, cd).End(xlUp).Row + 1
      Range(Cells(f, i), Cells(uf, i)).Copy Cells(ud, cd)
      Next
      End Sub

  3. Hola, no entiendo mucho de esto… quiero hacer lo mismo pero solo tengo 2 columnas y quiero que ambas esten en una sola. El codigo cómo cambia?

  4. Genial código. pero tenemos más de 15 digitos en la celda y lo tenemos que tratar como texto. Al activar la macros nos modifica los números, se puede modificar macro para que haga el transpose a texto también?

  5. rvaquerizo, amigo, hermano, no se si leas esto, pero me has salvado de una bien complicada, estoy que lloro. Muchas gracias en serio!!!!

  6. Hola, Buen día. Estaba tratando de dejar todo en una solo columna pero no podía. Y buscando encontré este excelente código. Muchas gracias. Excelente aporte un abrazo.

  7. Hola,

    bueno, muchas gracias por este código, la verdad quiero empezar diciendo que no sé absolutamente nada de Programación, pero necesitaba que no me transpusiera celda a celda recorriendo a lo largo de una misma fila sino que recorriera el rango a lo largo de una misma columna, le di diez millones de vueltas, hasta que lo logré, la verdad me apena porque era una tontería, solo decirle que empezara por j (columna), y luego recorriera i (fila) o al menos, así lo entendí cambiar ese orden en el código y ya, s los dejo por si le ayuda a alguien. GRACIAS A RVAQUERIZO POR ESTO TAN ÚTIL:

    Sub Columnas ()
    Dim rango As Variant
    Dim i As Long, j As Long, k As Long
    Dim col As Long

    rango = Selection.Value

    ‘Esta es la parte que permite ubicar la salida
    col = Selection.Column
    k = Selection.Row

    ‘Esto recorre el rango y realiza la trasposición
    For i = 1 To UBound(rango, 1)
    For j = 1 To UBound(rango, 2)
    Cells(k, col + UBound(rango, 2)).Value = rango(i, j)
    k = k + 1
    Next
    Next
    End Sub

    Chao!!

    1. Hola, perdón!!, acá está el cambio:

      Sub Columnas()
      Dim rango As Variant
      Dim i As Long, j As Long, k As Long
      Dim col As Long

      rango = Selection.Value

      ‘Esta es la parte que permite ubicar la salida
      col = Selection.Column
      k = Selection.Row

      ‘Esto recorre el rango y realiza la trasposición
      For j = 1 To UBound(rango, 2)
      For i = 1 To UBound(rango, 1)
      Cells(k, col + UBound(rango, 2)).Value = rango(i, j)
      k = k + 1
      Next
      Next
      End Sub

  8. Acabo de usarlo para un montón de palabras que necesitaba agrupar en una sola columna…No sé nada de macros y la verdad intenté hacer los pasos y simplemente me sorprendí porque solo pegué el código y di play en ejecutar y cuando vi estaba mi columna como la quería! MIL GRACIAS!

  9. ALGUIEN QUE ME AYUDE? NECESITO PASAR VARIAS COLUMNAS A UNA SOLA DE MANERA CONSECUTIVA? NO SE NADA DE PROGRAMACIÓN Y NO ENTIENDO! DE ANTEMANO GRACIAS!!!

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *