Cómo ordenar un array en PHP en base a uno de los valores de cada uno de sus elementos

El otro día un cliente me pidió que los datos de un informe aparecieran ordenados en base al stock. Para poneros en situación se trata de un informe que le exporto en Excel de su stock en una tienda WooCommerce. A priori, lo más sencillo sería hacer la consulta en base al stock, algo así como que al obtener productos WooCommerce me los devuelva ordenados por stock. En este caso, no era posible porque el informe realmente es una recopilación de stocks de no solo una tienda, sino de varias, y la estructura que tengo es un array PHP multidimensional.

Ordenación personalizada de listas en PHP

Así que nada, la solución es sencilla, usar la función usort de PHP, que permite ordenar un array siguiendo un criterio que definimos a nuestra elección. Esta función recibe el array como primer parámetro y lo hace por referencia, así que lo que le pases lo modifica; y un segundo parámetros, que es una función. La función puedes haberla definida aparte o puedes usar una función anónima, que es bastante práctico para este caso.

Así que bueno, teniendo ya la herramienta, vamos a explicar el detalle. Tenemos un array con este formato:

<?php
$datos = array( 
    array( 'sku' => 'XXXXX', 'stock' => 30, 'nombre' => 'Producto X' ...),
    array( 'sku' => 'YYYYY', 'stock' => 10, 'nombre' => 'Producto Y' ...),
    ....
);

Y queremos que se quede ordenado por stock de forma que el elemento 2º de este caso pasara a ser el 1º, porque su stock es menor y queremos tener la lista ordenada de menor a mayor, de forma ascendenten, en base a ese valor.

Pues con usort sería muy sencillo.

<?php
usort( $datos, function( $a, $b ){
    return $a['stock'] - $b['stock'];
} )

Una ordenación alfabética, ya que estamos, sería bien sencilla, usando esta misma lógica:

<?php
usort( $datos, function( $a, $b ){
    return strcmp( $a['nombre'], $b['nombre'] );
} )

Y cualquier otra ordenación que queráis que para eso vosotros definís el método de ordenación.

1 estrella2 estrellas3 estrellas4 estrellas5 estrellas (Ninguna valoración todavía)
Cargando…

Almacenamos las IPs desde la que se envían las valoraciones para evitar fraudes

0

Deja una respuesta

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

Carrito