Puede descargar el archivo seleccionaTabla.xlsm
Primero generamos una tabla con valores aleatorios y con un número de filas que podemos elegir, con un control numérico, entre 1 y 20.
La macro que genera la tabla con valores aleatorios es la siguiente.
Observe que se define la celda B4 como la esquina superior izquierda y en base a ella se genera toda la tabla. Esta esquina sería fácil de variar en el código de la macro, gracias al uso de
Offset
.
Sub generaTabla()
Dim n As Byte, i As Byte
Dim R As Range
Set R = Range("B4")
n = [I2]
Range("B5:F24").ClearContents
For i = 1 To n
R.Offset(i, 0) = i
R.Offset(i, 1).Value = WorksheetFunction.Choose(Int(Rnd() * 3) + 1, "Norte", "Sur", "Centro")
R.Offset(i, 2).Value = Date - i + 1
R.Offset(i, 3).Value = WorksheetFunction.Choose(Int(Rnd() * 3) + 1, "Libros", "Comic", "Web")
R.Offset(i, 4).Value = (Int(Rnd() * 100000) + 20000) / 100
Next i
End Sub
El código VBA que selecciona la tabla sin incluir la cabecera es la siguiente.
Sub seleccionaTablaSinCabecera()
Worksheets("Hoja1").Activate
'el cursor inicialmente tiene que estar dentro de la tabla
Range("B5").Select
Set R = ActiveCell.CurrentRegion
R.Offset(1, 0).Resize(R.Rows.Count - 1, R.Columns.Count).Select
End Sub
Aquí vemos otro uso estupendo de
Offset
combinado con Resize
, propiedad de los rangos que hemos visto recientemente. Puede verlo en el post siguiente.Excel
via [ExcelAvanzado.com] [https://ift.tt/2LkMymp]
June 3, 2018 at 04:02AM
No hay comentarios.:
Publicar un comentario