Así lo he hecho, he aceptado la segunda columna de anotación y he añadido una macro:
Private Sub Worksheet_Calculate()
Dim f As Long
Dim disparar As Boolean
' Si ya se disparó una vez, salimos
If Me.Range("XX2").Value <> "" Then Exit Sub
' Comprobamos si alguna W llegó a 2
For f = 2 To 6
If Me.Cells(f, "W").Value = 2 Then
disparar = True
Exit For
End If
Next f
' Si ninguna llegó a 2, no hacemos nada
If disparar = False Then Exit Sub
' Guardamos TODO el rango como base
For f = 2 To 6
Me.Cells(f, "XX").Value = Me.Cells(f, "W").Value
' Fórmula en Y restando su base
Me.Cells(f, "Y").FormulaLocal = _
"=CONTAR.SI.CONJUNTO(Datos!B:B;$V$1;Datos!D:D;$V" & f & ")" & _
"-CONTAR.SI.CONJUNTO(Datos!B:B;$V$1;Datos!E:E;$V" & f & ")" & _
"-XX" & f
Next f
End Sub
No es la opción más bonita porque sigue contando los objetos en la columna W, pero la función me resulta suficiente para poder llevar la cuenta.
Tendré que hacer una pequeña macro para cada jugadora, son 14, pero espero no tener problemas
Por
Maku, · publicado
Navegando por la red he encontrado un código para seleccionar objetos de autocad, es el siguiente:
Public AcadDoc As Object
Public AcadUtil As Object
Dim objLinea As AcadObject
Dim Punto As Variant
Sub MacroSeleccion()
Set AcadDoc = GetObject(, "Autocad.Application").ActiveDocument
Set AcadUtil = GetObject(, "Autocad.Application").ActiveDocument.Utility
AcadDoc.Utility.GetEntity objLinea, Punto, "Selecione objeto: "
End Sub
Sin embargo, al ejecutarse en autocad sólo me pone que designe los objetos. No me los selecciona automáticamente.
He encontrado otro código similar, pero no me funciona. Creo que es más adecuado que el otro: es el siguiente:
Dim SS As AcadSelectionSet
Set SS = ThisDrawing.SelectionSets.Add("Prueba")
Call SS.SelectOnScreen
SS.Delete
Dim Entidad as AcadEntity
Set Entidad = SS(0)
el problema creo que está en ThisDrawing.SelectionSets.Add("Prueba")
Si alguien puede echar una mano. Lo único que deseo es seleccionar las líneas del espacio modelo de autocad para copiarlas.