• 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
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad
    • Tiendas afiliadas
      • AliExpress
      • Amazon
      • Banggood
      • GeekBuying
      • Lenovo

Analytics Lane

Ciencia e ingeniería de datos aplicada

  • Ciencia de datos
  • Machine Learning
  • Python
  • Pandas
  • NumPy
  • Matlab
  • Julia
  • JavaScript
  • Excel

NumPy: Ordenar en base a la suma de las columnas o filas de matrices NumPy

julio 20, 2021 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 3 minutos

NumPy

El año pasado publiqué una entrada en la que se enseñaba a ordenar las matrices de NumPy en base a los valores de una fila o columna. Para lo que se usaba el método argsort(). En esta ocasión veremos otro problema similar y bastante habitual: ordenar en base a la suma de las columnas o de las filas.

Obtener la suma de las columnas o filas en NumPy

Para continuar es necesario crear primero una matriz, para lo que se puede usar simplemente el siguiente código

import numpy as np

arr = np.array([[21, 12, 33],
                [12,  7, 13],
                [31, 20, 21]])

Ahora, la suma de los elementos de esta matriz se puede obtener mediante el método sum() que tienen los objetos ndarray. Un método que si no se indica nada devuelve la suma de todos los elementos, pero, mediante la propiedad axis, es posible indicarle que se desea la suma de las filas (1) o columnas (0). Por ejemplo, para obtener la suma de las columnas se puede escribir

arr.sum(axis=0)
array([64, 39, 67])

Ordenar en base a la suma de columnas

Ahora bien, para reordenar la matriz en base a estos valores es necesario obtener los índices que ordenaría este vector, lo que nos proporciona el método argsort(). Así se pueden obtener los índices mediante la línea

arr.sum(axis=0).argsort()
array([1, 0, 2])

Donde se puede ver que en la segunda posición se encuentra la columna cuya suma es la menor de las tres, en la primera el valor intermedio y en la última con la mayor suma. Esto es, los índices con los que se podría ordenar la matriz en orden ascendente.

Publicidad


arr.sum(axis=0)[arr.sum(axis=0).argsort()]
array([39, 64, 67])

Lo que también se puede emplear para ordenar las columnas de la matriz en base a la suma de estas. Algo que se puede, tal como se explicó anteriormente, se puede obtener simplemente con el siguiente código.

arr[:, arr.sum(axis=0).argsort()]
array([[12, 21, 33],
       [ 7, 12, 13],
       [20, 31, 21]])

Ordenar en orden decreciente

Desafortunadamente, el método argsort() no dispone de una propiedad con la que se obtengan los índices que ordenen el vector original en orden descendente. Aunque esto es algo que se puede solucionar fácilmente mediante el uso del operador :, simplemente invirtiendo el orden del array tal como se muestra a continuación.

arr[:, arr.sum(axis=0).argsort()[::-1]]
array([[33, 21, 12],
       [13, 12,  7],
       [21, 31, 20]])

Ordenar en base a la suma de las filas

Finalmente, para ordenar en base a la suma de las filas solamente hay que cambiar el eje sobre el que suma el método sum(), obtener los indices correspondientes y aplicarlos para ordenar las filas. Así para ordenar en base a la suma de las filas solamente hay que escribir.

arr[arr.sum(axis=0).argsort()]
array([[12,  7, 13],
       [21, 12, 33],
       [31, 20, 21]])

Conclusiones

En esta ocasión hemos visto cómo se puede ordenar en base a la suma de las columnas o filas la matriz NumPy. Comprobado como una operación que es bastante habitual se puede realizar fácilmente en Python combinando el uso de los métodos sum() y argsort().

¿Te ha parecido de utilidad el contenido?

¡Puntúalo entre una y cinco estrellas!

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

Publicidad


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

  • Cómo encontrar la posición de elementos en una lista de Python
    Cómo encontrar la posición de elementos en una lista de…
  • NumPy
    NumPy: La función reshape de NumPy con ejemplos
  • Numpy básico: seleccionar filas y columnas en matrices Numpy
    Numpy básico: seleccionar filas y columnas en matrices Numpy
  • NumPy
    NumPy: Obtener los índices de los máximos de un vector
  • NumPy
    NumPy: Insertar valores en matrices de NumPy
  • NumPy
    NumPy: Crear matrices vacías en NumPy y adjuntar filas o…

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.

Publicidad




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
  • Facebook
  • GitHub
  • Instagram
  • Pinterest
  • RSS
  • Twitter
  • Tumblr
  • YouTube

Publicidad

Entradas recientes

El método de Hare-Niemeyer y su implementación en Python

septiembre 29, 2023 Por Daniel Rodríguez

Redimensionar una partición de disco LVM con espacio no asignado en Linux

septiembre 27, 2023 Por Daniel Rodríguez

¿Cómo saber la versión de Pandas o cualquier otra librería en Python?

septiembre 25, 2023 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Unir y combinar dataframes con pandas en Python publicado el septiembre 10, 2018 | en Python
  • ¿Cómo cambiar el nombre de las columnas en Pandas? publicado el mayo 6, 2019 | en Python
  • Ecuaciones multilínea en Markdown publicado el septiembre 14, 2022 | en Herramientas
  • Numpy básico: valores mínimos y máximos en arrays Numpy publicado el octubre 23, 2019 | en Python
  • pandas Pandas: Cambiar los tipos de datos en los DataFrames publicado el julio 15, 2021 | en Python

Publicidad

Lo mejor valorado

4.9 (22)

Seleccionar filas y columnas en Pandas con iloc y loc

4.7 (12)

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

4.6 (15)

Archivos JSON con Python: lectura y escritura

4.5 (10)

Diferencias entre var y let en JavaScript

4.3 (12)

Ordenación de diccionarios en Python mediante clave o valor

Publicidad

Comentarios recientes

  • Daniel Rodríguez en ¿Cómo eliminar columnas y filas en un dataframe pandas?
  • Miguel en ¿Cómo eliminar columnas y filas en un dataframe pandas?
  • alberto en Resolver problema de credenciales en Bitbucket
  • Pablo en Aplicar el método D’Hondt en Excel
  • Agapito en Creación de un EXE desde un archivo Python en Windows

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-2023 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto