ChatGPT es una herramienta de I.A. que permite hacer consultas a diversos temas. Desde obtener la sinopsis de alguna novela o hasta la generación de código.
En este post continuaremos haciendo algunas consultas para ver la potencialidad de esta herramienta que, queramos o no, está para quedarse.
¿Cómo usar ChatGPT?
Respuesta corta: Escribiremos una orden y el asistente nos dará una respuesta.
Primera orden: Obtener toda la suma de este texto "María tiene 3 gatos, Juan 5, Miguel 2 y Horacio 7" usando regex de Javascript.
Respuesta:
const texto = "María tiene 3 gatos, Juan 5, Miguel 2 y Horacio 7"; const regex = /\d+/g; const numeros = texto.match(regex); const suma = numeros.reduce((acc, val) => acc + parseInt(val), 0); console.log(suma); // Output: 17
También nos provee de una explicación:
En este código, usamos la expresión regular /\d+/g para buscar todas las apariciones de uno o más dígitos en el texto.
Luego, usamos el método match() para obtener un array con todos los números encontrados en el texto. Finalmente, usamos el método reduce() para sumar todos los valores del array numeros.
El segundo argumento de reduce() inicializa el valor del acumulador en cero. El resultado se almacena en la variable suma, que es 17 en este caso.
Segunda orden: Validar este patrón " ^\w{2}-MX\d{4}$" en C.
Respuesta:
#include <stdio.h> #include <regex.h> int main() { regex_t regex; int reti; char msgbuf[100]; // Compile el patrón regular reti = regcomp(®ex, "^[A-Z]{2}-MX[0-9]{4}$", 0); if (reti) { fprintf(stderr, "Error compilando el patrón regular\n"); return 1; } // Compruebe la cadena de entrada reti = regexec(®ex, "AB-MX1234", 0, NULL, 0); if (!reti) { printf("La cadena coincide con el patrón regular\n"); } else if (reti == REG_NOMATCH) { printf("La cadena no coincide con el patrón regular\n"); } else { regerror(reti, ®ex, msgbuf, sizeof(msgbuf)); fprintf(stderr, "Error al ejecutar la expresión regular: %s\n", msgbuf); return 1; } // Libere la memoria utilizada para el patrón regular regfree(®ex); return 0; }
Explicación:
En este ejemplo, el patrón regular se compila utilizando regcomp() y se comprueba utilizando regexec().
Si la cadena de entrada coincide con el patrón, se imprimirá "La cadena coincide con el patrón regular".
Si no coincide, se imprimirá "La cadena no coincide con el patrón regular".
Si ocurre algún error al compilar o ejecutar el patrón regular, se imprimirá un mensaje de error correspondiente.
Tercera orden: Que texto cumple el patrón: /resume..txt/
Respuesta:
El patrón /resume..txt/ coincide con cualquier texto que tenga "resume" seguido de cualquier caracter (excepto nueva línea) dos veces y luego seguido de ".txt".
Por ejemplo:
"resume01.txt"
"resume99.txt"
"resume00.txt"
"resumexxt.txt"
Cuarta orden: Qué hace esta instrucción "lsof -i :8080"
Respuesta:
La instrucción "lsof -i :8080" muestra una lista de todos los procesos que están usando el puerto 8080 en un sistema operativo basado en Unix.
"lsof" significa "list open files" y "-i :8080" filtra los resultados para mostrar sólo los procesos que están utilizando el puerto 8080.
Quinta orden: Un patrón que no permita que una palabra termine en .pdf o .PDF
Respuesta:
/^(?i).*(?<!\.pdf)$/
Explicación:
Este patrón utiliza una "negative lookbehind assertion" para asegurarse de que la palabra no termine en ".pdf" o ".PDF".
La expresión (?<!\.pdf)$ verifica que la palabra no termina en ".pdf" o ".PDF" utilizando el operador <!, que es un "negative lookbehind assertion". La parte (?i) al inicio indica que la búsqueda es insensible a mayúsculas y minúsculas.
Como se puede observar, podemos usar esta herramienta como asistente. Sin embargo, hay que tener claro que las respuestas, aunque válidas, no siempre son las correctas o las más óptimas.
Comentarios
Publicar un comentario