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
Estimados,
Tengo el siguiente códgio para crear citas desde una macro.
Private Sub CommandButton1_Click()
Dim Respuesta As VbMsgBoxResult
Dim ol As New Outlook.Application
Dim ns As Outlook.Namespace
Dim itmApoint As Outlook.AppointmentItem
Set ns = ol.GetNamespace("MAPI")
Set itmApoint = Outlook.Application.CreateItem(olAppointmentItem)
With itmApoint
.Start = "2014-05-22 13:00:00"
.End = "2014-05-22 13:00:00"
.Subject = "Prueba"
.Body = "Prueba"
.Importance = olImportanceNormal
.Save
End With
MsgBox "Se creó el recordatorio en Outlook", vbInformation, "Mensaje"
End Sub
Este código me funciona muy bien en algunas máquinas, pero en otras me da el siguiente error:
Se ha producido el error 13 en tiempo de ejecucion
No Coinciden los tipos
Y es en la línea:
Set itmApoint = Outlook.Application.CreateItem(olAppointmentItem)
Muchas Graicas por sus comentarios.
Saludos,