29 mayo, 2023

ELIMINAR DUPLICADOS EN UNA CADENA DE TEXTO Y ORDENAR CON TYPESCRIPT

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.

Donate Button with Credit Cards

¡¡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

Comparte este post

Si te ha gustado o tienes alguna duda, puedes dejar aquí tu comentario.

Este sitio web utiliza cookies para que usted tenga la mejor experiencia de usuario. Si continúa navegando está dando su consentimiento para la aceptación de las mencionadas cookies y la aceptación de nuestra política de cookies, pinche el enlace para mayor información.plugin cookies

ACEPTAR
Aviso de cookies