Como Contar Datos Con Una Condicion en Una Columna con CountIf





En este poste se presenta una sencilla, pero útil macro que permite contar datos en Excel dependiendo de una condición, se apela a WorksheetFunction, que son las funciones de Excel que se pueden usar en macros de VBA, también se presentó otros ejemplos relacionados: como contar datos que cumplan con varias condiciones, como contar celdas vacías, como contar cualquier tipo de dato de un rango, como contar valores en un rango.

Desde el final del post se puede descargar el ejemplo en forma gratuita sin ninguna restricción, el código se puede adaptar a cada necesidad, Aporta por favor para sostener el sitio si está dentro de tus posibilidades, desde ya muchas gracias.

Si te estás iniciando en la operación de Excel o requieres afirmar conocimientos, recomiendo leer un excelente libro sobre Excel que te ayudará operar las planillas u hojas de cálculo, haz click acá, si quieres aprender sobre Excel, en inglés, entonces debes hacer click here. Si lo que necesitas es aprender o profundizar sobre la programación de macros con VBA este es unos de los mejores cursos on line que he visto en internet.

  

El vídeo verás la macro en acción con una explicación más detallada de su codificación y funcionamiento, recomiendo observar para una más fácil comprensión de la macro; suscribe a nuestra web desde la parte superior derecha de la página ingresando tu mail y a nuestro canal de You Tube para recibir en tu correo vídeos explicativos sobre macros interesantes, como  por ejemplo Recorre fila buscando y comparando datos de dos columnas en hojas distintasbuscar en listbox mientras escribes en textbox, como crear una factura o sale invoice y grabar guardar PDF XLS y enviar por mail, trabajando con filas, celdas, columnas, rangos y muchos ejemplos más.






  

Al descargar el archivo se observa un botón que permite ejecutar una macro que cuenta todos los valores que cumplen una cierta condición y escribe el resultado en la celda siguiente a la última fila con datos.

En este ejemplo se determina cual es la ultima fila con datos y en ese rango se procede a contar los valores que cumplan la condición de ser mayores a 100.000 (cien mil); si el valor de la celda cumple esa condición es contado por la macro, escribiendo en la celda A25 el resultado de la cuenta realizada.

⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛
Quizá sea de utilidad también

Como llenar combobox y buscar datos


Cronometro en VBA para Excel

Formulario de VBA para insertar datos

⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛



⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛⇛

Para contar se utiliza WorksheetFunctión, que como ya se explicó en post anteriores permite usar todas o mejor dicho casi todas, porque algunas funciones no se pueden usar, en macros programadas con VBA (Visual Basic Aplication), en código que permite contar datos con una condición en una columna de Excel es:

Application.WorksheetFunction.CountIf(Range("A2" & ":A" & uf - 1), ">100000")

Como se observa en el código anterior es necesario determinar el rango donde la función debe realizar la cuenta y como segundo item el criterio que debe tener en cuenta, en este caso > 100000, a continuación se muestra el código completo.


Código que se inserta en un módulo

Sub CuentaIf()
Application.ScreenUpdating = False
On Error Resume Next
Dim uf As String
uf = Sheets("Hoja1").Range("A" & Rows.Count).End(xlUp).Row
Cells(uf, "A").ClearContents
Cells(uf, "A") = Application.WorksheetFunction.CountIf(Range("A2" & ":A" & uf - 1), ">100000")
MsgBox ("La cantidad de registros es: " & Cells(uf, "A")), vbInformation, "AVISO"
DisplayAlerts = True
Application.ScreenUpdating = True
End Sub


Si te fue de utilidad puedes INVITARME UN CAFÉ y de esta manera ayudar a seguir manteniendo la página, CLICK para descargar en ejemplo en forma gratuita.


If this post was helpful INVITE ME A COFFEE and so help keep up the page, CLICK to download free example.


Si te gustó por favor compártelo con tus amigos
If you liked please share it with your friends