• Saltar al contenido principal
  • Skip to secondary menu
  • Saltar a la barra lateral principal
  • Saltar al pie de página
  • Inicio
  • Secciones
    • Ciencia de datos
    • Criptografía
    • Herramientas
    • Machine Learning
    • Noticias
    • Opinión
    • Productividad
    • Programación
      • JavaScript
      • Julia
      • Matlab
      • Python
      • R
  • Programación
    • JavaScript
    • Julia
    • Matlab
    • Python
    • R
  • Laboratorio
    • Estadística
      • Calculadora del Tamaño Muestral en Encuestas
      • Calculadora de estadísticos descriptivos
      • Test de normalidad
      • Calculadora de contrastes de hipotesis
      • Calculadora de tamano del efecto
      • Simulador de Regresión Lineal con Ruido
      • Visualizador de PCA
      • Visualizador de Series Temporales
      • Simulador de Regresión Logística
      • Simulador de K-Means
      • Simulador de DBSCAN
      • Detector de la Ley de Benford
    • Probabilidad
      • Calculadora de Probabilidad de Distribuciones
      • Calculadora de Probabilidades de Lotería
      • Simulador del Problema de Monty Hall
      • Simulador de la Estrategia Martingala
    • Finanzas
      • Calculadora de Préstamos e Hipotecas
      • Conversor TIN ↔ TAE
      • Calculadora DCA con ajuste por inflación
      • Simulador FIRE (Financial Independence, Retire Early)
    • Herramientas
      • Formateador / Minificador de JSON
      • Comparador y Formateador de Texto y JSON
      • Formateador y Tester de Expresiones Regulares
      • Inspector de JWT
      • Generador y verificador de hashes
      • Codificador / Decodificador Base64 y URL
      • Conversor de bases numericas
      • Conversor de Timestamp Unix
      • Conversor de colores
      • Generador de UUIDs
    • Juegos
      • Tres en Raya
      • Nim con Q-Learning
    • Más
      • Método D’Hondt
      • Generador de Contraseñas Seguras
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad

Analytics Lane

Ciencia e ingeniería de datos aplicada

  • Ciencia de datos
  • Machine Learning
  • IA Generativa
  • Python
  • Pandas
  • NumPy
  • R
  • Excel

NumPy: Comprobar todos los valores de una matriz de NumPy

mayo 31, 2021 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 5 minutos

Una de las grandes ventajas de las matrices de NumPy es la posibilidad de realizar operaciones lógicas sobre ellas, como puede ser el caso de igualdades o comparaciones. El resultado de estas operaciones es una nueva matriz de valores lógicos donde se muestra el resultado de aplicar la operación sobre cada uno de los elementos. Algo con lo que es posible paralelizar análisis de datos, permitiendo comprobar todos los valores de una matriz de NumPy mediante una única operación. Lo que se puede combinar con las funciones np.all() y np.any() para comprobar si todos los elementos cumplen la condición. Algo que puede ser de gran utilidad como se muestra en los siguientes ejemplos.

Tabla de contenidos

  • 1 Comprobar que todos los elementos de una matriz de NumPy son cero
  • 2 Comprobar si algún elemento es diferente de cero en una matriz de NumPy
  • 3 Comprobar cuántos valores son diferentes de cero en una matriz de NumPy
  • 4 Obtener el número de valores que sean mayores que un valor en una matriz de NumPy
  • 5 Combinar varias condiciones
  • 6 Comprobar valores sobre matrices 2D de NumPy
  • 7 Conclusiones

Comprobar que todos los elementos de una matriz de NumPy son cero

Supongamos que tenemos una matriz con miles o decenas de miles de elementos. En el caso de querer comprobar si todos los valores son iguales o no a cero se puede hacer simplemente comparando la matriz de NumPy a cero. Obteniendo un vector con los mismos elementos de valores lógicos. Algo similar a lo que se muestra en el siguiente ejemplo.

In[1]:  import numpy as np

        arr = np.array([0, 0, 0])
        arr == 0

Out[1]: array([ True,  True,  True])

Ahora, si queremos saber si todos los elementos son iguales o no a cero únicamente tenemos que revisar el vector. Algo que es fácil en el ejemplo, pero no en un caso con miles de elementos. Para solucionar esto existe la función np.all() la cual nos devuelve verdadero en el caso de que todos los elementos sean verdadero y falso el el resto de los casos. Con la que fácilmente se puede saber si todos los elementos cumplen o no la condición.

Nuevo simulador FIRE en el laboratorio de aplicaciones de Analytics Lane
En Analytics Lane
Nuevo simulador FIRE en el laboratorio de aplicaciones de Analytics Lane

In[2]:  np.all(arr == 0)

Out[2]: True

Comprobar si algún elemento es diferente de cero en una matriz de NumPy

En el ejemplo anterior se ha obtenido verdadero porque todos los elementos son iguales a cero, en el caso de que no lo fuese se obtendría un valor igual a falso. Otra forma de obtener este resultado es comprobar si hay algún valor diferente de cero. Lo que se puede conseguir mediante el uso de la función np.any() una función que devuelve verdadero si al menos un elemento de la matriz es verdadero y falso en cualquier otro caso. Así se puede comprobar que para el ejemplo anterior no existe ningún valor distinto de cero.

In[3]:  np.all(arr != 0)

Out[3]: False

Otra cosa es que se cambie el contenido del vector por uno como el siguiente.

In[4]:  arr = np.array([0, 0, 0, 1, 0, 1])
		arr != 0

Out[4]: array([False, False, False,  True, 

Con lo cual se obtendría una respuesta afirmativa a la pregunta de si existe un valor distinto de cero.

In[5]:  np.any(arr != 0)

Out[5]: True

Publicidad


Comprobar cuántos valores son diferentes de cero en una matriz de NumPy

Una vez que sabemos que existe, por lo menos, un elemento distinto de cero en la matriz una pregunta que puede surgir es cuántos son. Para ello se puede usar la función np.sum() ya que al sumar sobre datos booleanos el valor verdadero es un uno y los valores falsos son cero. Así se puede saber rápidamente la cantidad de valores que cumplen la condición de ser distintos de cero.

In[6]:  np.sum(arr != 0)

Out[6]: 2

Obtener el número de valores que sean mayores que un valor en una matriz de NumPy

Lo que se ha visto en las secciones anteriores se puede aplicar también sobre cualquier otra operación lógica. Se puede comprobar si los valores de una matriz son mayores, menores, iguales o cualquier combinación que se nos pueda ocurrir. Así para saber cuántos elementos son mayores que tres solamente se tiene que hacer algo como lo que se muestra a continuación.

In[7]:  arr = np.array([1, 2, 3, 4, 5])
		np.sum(arr > 3)

Out[7]: 2

Combinar varias condiciones

Otra necesidad con la que nos podemos encontrar es con la necesidad de validar dos condiciones, por ejemplo, comprobar los elementos que son mayores de un valor y menor de otro. Para lo que es necesario usar alguna función como puede ser np.logical_and().

In[8]:  np.logical_and(arr > 1, arr < 5)

Out[8]: array([False,  True,  True,  True, False])

Alternativamente también se puede usar el operador & como una versión corta del anterior.

In[9]:  (arr > 1) & (arr < 5)

Out[9]: array([False,  True,  True,  True, False])

Lo que se puede combinar fácilmente como las funciones vistas anteriormente como es el caso de np.sum().

In[10]:  np.sum((arr > 1) & (arr < 5))

Out[10]: 3

Publicidad


Comprobar valores sobre matrices 2D de NumPy

Una vez llegado a este punto nos podemos plantear si los métodos vistos pueden trabajar sobre matrices 2D. La respuesta es que funcionan exactamente igual. Por ejemplo, la función np.all() devuelve verdadero si todos los elementos de la matriz 2D cumplen la condición.

In[11]:  arr = np.array([[0, 0, 0], [0 ,1, 0], [1, 0, 1]])
         arr == 0

Out[11]: array([[ True,  True,  True],
                [ True, False,  True],
                [False,  True, False]])

In[12]:  np.all(arr == 0)

Out[12]: False

Aunque en este caso se puede llevar a cabo también un análisis por fila o columna, indicando para ello la propiedad axis. Pudiendo saber de este modo si todos los elementos de una columna (el eje 0 de la matriz) son cero

In[13]:  np.all(arr == 0, axis=0)

Out[13]: array([False, False, False])

En este caso en ninguna de las columnas los valores son todos igual a cero, pero esto sí que sucede en la primera columna. Lo que se puede validar mediante el uso de la siguiente expresión.

In[14]:  np.all(arr == 0, axis=1)

Out[14]: array([True, False, False])

Algo que funciona exactamente igual para la función suma, con la que se puede comprobar cuántos valores son cero en toda la matriz.

In[15]:  np.sum(arr == 0)

Out[15]: 6

O en cada una de las filas.

In[16]:  np.sum(arr == 0, 1)

Out[16]: array([3, 2, 1])

Conclusiones

En esta ocasión hemos visto cómo se pueden utilizar las funciones np.all(), np.any() y np.sum() para comprobar todos los valores de una matriz de NumPy de una forma fácil y sencilla. La primera de las funciones, np.all(), nos ayuda a comprobar si todas los valores cumplen una condición. Mientras que la segunda, np.any(), comprueba si alguna cumple la condición. Finalmente, el uso de np.sum() nos permite saber cuántas veces se cumple la condición.

Imagen de bettinabef en Pixabay

¿Te ha parecido de utilidad el contenido?

¡Puntúalo entre una y cinco estrellas!

Puntuación promedio 0 / 5. Votos emitidos: 0

Ya que has encontrado útil este contenido...

¡Síguenos en redes sociales!

¡Siento que este contenido no te haya sido útil!

¡Déjame mejorar este contenido!

Dime, ¿cómo puedo mejorar este contenido?

Publicaciones relacionadas

  • Nuevo simulador FIRE en el laboratorio de aplicaciones de Analytics Lane
  • Nueva calculadora de préstamos e hipotecas en el laboratorio de aplicaciones de Analytics Lane
  • Hardening avanzado de NGINX: CSP, OCSP Stapling y defensa en profundidad
  • Nuevo generador y verificador de hashes en el laboratorio de aplicaciones de Analytics Lane
  • Nueva simulación de la estrategia Martingala en ruleta en el laboratorio de aplicaciones de Analytics Lane
  • Exactitud, precisión, recall… y los errores que cometemos al interpretarlas en proyectos reales
  • Nuevo simulador del problema de Monty Hall en el laboratorio de aplicaciones de Analytics Lane
  • Nuevo simulador interactivo de K-Means en el laboratorio de aplicaciones de Analytics Lane
  • Por qué los chatbots de inteligencia artificial parecen estar siempre de acuerdo contigo – Conversar con una inteligencia artificial – Parte I

Publicado en: Python Etiquetado como: NumPy

Interacciones con los lectores

Deja una respuesta Cancelar la respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

I accept the Terms and Conditions and the Privacy Policy

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

Barra lateral principal

Suscríbete a nuestro boletín

Suscríbete al boletín semanal para estar al día de todas las publicaciones.

Política de Privacidad

Analytics Lane en redes sociales

  • Amazon
  • Bluesky
  • Facebook
  • GitHub
  • Instagram
  • Mastodon
  • Pinterest
  • RSS
  • Telegram
  • Tumblr
  • Twitter
  • YouTube

Publicidad

Entradas recientes

Nueva herramienta: Comparador y Formateador de Texto y JSON en el laboratorio de Analytics Lane

abril 21, 2026 Por Daniel Rodríguez

Chatbots vs redes sociales: la diferencia clave entre la inteligencia artificial y los algoritmos de recomendación – Conversar con una inteligencia artificial – Parte II

abril 21, 2026 Por Daniel Rodríguez

Nueva Calculadora de Estadísticos Descriptivos en el laboratorio de aplicaciones de Analytics Lane

abril 20, 2026 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Buscar en Excel con dos o más criterios publicado el septiembre 7, 2022 | en Herramientas
  • Gráfica con los datos y las anomalías detectadas con OneClass SVM One-Class SVM: Detección de anomalías con máquinas de vector soporte publicado el marzo 15, 2024 | en Ciencia de datos
  • Método del codo (Elbow method) para seleccionar el número óptimo de clústeres en K-means publicado el junio 9, 2023 | en Ciencia de datos
  • Gráficos de barras en Matplotlib publicado el julio 5, 2022 | en Python
  • La similitud de Jaro–Winkler publicado el junio 24, 2020 | en Ciencia de datos, R

Publicidad

Lo mejor valorado

4.9 (24)

Seleccionar filas y columnas en Pandas con iloc y loc

4.6 (16)

Archivos JSON con Python: lectura y escritura

4.4 (14)

Ordenación de diccionarios en Python mediante clave o valor

4.7 (13)

Operaciones de filtrado de DataFrame con Pandas en base a los valores de las columnas

4.9 (11)

Pandas: Cambiar los tipos de datos en los DataFrames

Comentarios recientes

  • M. Pilar en Cómo eliminar las noticias en Windows 11 y recuperar tu concentración
  • Daniel Rodríguez en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • Pepe en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • CARLOS ARETURO BELLO CACERES en Justicio: La herramienta gratuita de IA para consultas legales
  • Piera en Ecuaciones multilínea en Markdown

Publicidad


Footer

Analytics Lane

  • Acerca de Analytics Lane
  • Boletín de noticias
  • Contacto
  • Libros
  • Lo más popular
  • Noticias
  • Tienda
  • Tiendas afiliadas

Secciones

  • Ciencia de datos
  • Criptografía
  • Herramientas
  • Machine Learning
  • Opinión
  • Productividad
  • Programación
  • Reseñas

Sobre de Analytics Lane

En Analytics Lane tratamos de explicar los principales conceptos de la ciencia e ingeniería de datos con un enfoque práctico. Los principales temas tratados son ciencia de datos, ingeniería de datos, inteligencia artificial, machine learning, deep learning y criptografía. Además, también se habla de los principales lenguajes de programación y herramientas utilizadas por los científicos e ingenieros de datos.

Copyright © 2018-2026 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto