Hola a todos!
Después de realizar la publicación del post anterior sobre eliminar duplicados en una cadena de texto (que en realidad debemos transformar previamente en un array , o más bien arreglo), me dí cuenta que quizás sería también interesante que después de eliminar los duplicados también los ordenase.
Por ello, y siguiendo con la función de ayer con la que seleccionábamos el contenido de una celda y obtenemos únicos, hoy modificaremos el código con la función sort() para ordenar previamente todos los elementos y luego eliminar los duplicados.
La función previa es esta:
/** @CustomFunction */
function SINDUPLICADOS(MiCelda) {
MiCelda = MiCelda.toString().replace(/\s/g, "");
// Indicar para la función split el delimitador, en este caso la coma
// Indicar para la función join, el delimitador de unión, en este caso la coma
MiCelda = Array.from(new Set(MiCelda.split(','))).join(', ');
return (MiCelda)
}
En la que después de obtener el string de la celda o en caso de número, pasarlo a texto, extraemos únicos.
Pues bien, si queremos ordenar debemos introducir sort() en el lugar que os indico en rojo:
/** @CustomFunction */
function SINDUPLICADOS_SORT(MiCelda) {
MiCelda = MiCelda.toString().replace(/\s/g, "");
// Indicar para la función split el delimitador, en este caso la coma
// Indicar para la función join, el delimitador de unión, en este caso la coma
MiCelda = Array.from(new Set(MiCelda.split(',').sort())).join(', ');
return (MiCelda)
}
El resultado es el que podéis ver en la imagen, donde os dejo los dos scripts:

Es importante tener en cuenta que la ordenación es para texto y no para números, para la que no sirve el método Sort() de ordenación.
Espero que os sea de utilidad!!
¿Te ha resultado de interés?, puedes apoyar a Excel Signum con una pequeña donación.
¡¡Muchas gracias!!
Mediante la suscripción al blog, la realización comentarios o el uso del formulario de contacto estás dando tu consentimiento expreso al tratamiento de los datos personales proporcionados según lo dispuesto en la ley vigente (LOPD). Tienes más información al respecto en esta página del blog: Política de Privacidad y Cookies