2010-09-10 29 views
7

Este no es el problema usedrange.
Por ejemplo, en usuario de Excel selecciona un rango (posiblemente vacía) a través del ratón, digamos B4: C12Excel VBA obtiene rango de rango seleccionado por el mouse

Y digamos que después de esto sin anular el usuario gama presiona la macro y macro debe decirle B4: C12.

¿Alguien puede mostrar un ejemplo?

La macro debe haber algo en la línea de lo siguiente:

Sub showrng() 
    MsgBox SelectedRange.Address(ReferenceStyle:=xlA1) 
End Sub 

Respuesta

11
Sub macro1() 
    MsgBox Selection.Address(ReferenceStyle:=xlA1, _ 
          RowAbsolute:=False, ColumnAbsolute:=False) 
End Sub 

HTH!

+1

+1 pero ReferenceStyle: = xlA1 quisiste emparejar los requisitos de la pregunta más de cerca – barrowc

3
Sub macro1() 
    MsgBox Selection.Address 
End Sub 

o

Sub macro1() 
    Dim addr as String 
    addr = Selection.Address 
    msgbox addr 

    ' Now, as we found the address, according to that... you can also do other operations 

End Sub 
1

como selecciones pueden incluir varias gamas, independientes, el código siguiente muestra una solución más completa para el problema:

Public Sub SelectionTest() 
Dim r As Range 
Dim s As String 

    Select Case Selection.Areas.Count 
    Case 0: 
    MsgBox "Nothing selected." 
    Case 1: 
    MsgBox "Selected range: " & Selection.Areas(1).Address(False, False) 
    Case Else 
    s = "" 
    For Each r In Selection.Areas 
     s = s + vbNewLine + r.Address(False, False) 
    Next r 
    MsgBox "Selected several areas:" & s 
    End Select 

End Sub 
Cuestiones relacionadas