Escribir en archivos en Node.js

    Introducción

    Escribir en archivos es una necesidad frecuente al programar en cualquier lenguaje. Al igual que otros lenguajes de programación, JavaScript con Node.js hace que el manejo del sistema de archivos sea intuitivo mediante el uso de un módulo que se ocupa del sistema de archivos del sistema operativo.

    los fs El módulo contiene la funcionalidad para manipular archivos y tratar con el sistema de archivos de la plataforma informática. Además de leer y escribir en archivos, puede utilizar el módulo para consultar estadísticas de archivos, como tamaños y recuentos de archivos.

    Por defecto, el fs El módulo escribirá archivos con una codificación de ‘utf8’. UTF-8 es una codificación comúnmente utilizada en páginas web y otros documentos. La codificación de archivos se refiere al conjunto de caracteres que se utiliza para el contenido del archivo. Las codificaciones más utilizadas son ‘utf8’, ‘ascii’, ‘binary’, ‘hex’, ‘base64’ y ‘utf16le’.

    Cada codificación de caracteres tiene ventajas específicas y casos en los que tiene más sentido. Por ejemplo, ‘ascii’ es una codificación fácil de leer y escribir, pero eliminará el bit alto del flujo de datos. Por razones como esta, querrá seleccionar la codificación de caracteres con cuidado.

    En las próximas secciones presentaremos las diferentes formas fs le permite escribir en el sistema de archivos, incluidas sus diferencias y ventajas.

    Método 1: usar fs.writeFile

    los fs módulo incluye un alto nivel writeFile método que puede escribir datos en archivos de forma asincrónica. Esto significa que, al igual que con muchas operaciones en Node.js, la E / S no se bloquea y emite un evento cuando finaliza la operación. Podemos escribir una función de devolución de llamada para que se ejecute cuando el writeFile devoluciones.

    Te puede interesar:Siga los redireccionamientos en cURL

    Aquí hay un ejemplo de código simple de cómo escribir algunas letras de canciones en un archivo:

    // writefile.js
    
    const fs = require('fs');
    
    let lyrics="But still I"m having memories of high speeds when the cops crashedn' + 
                 'As I laugh, pushin the gas while my Glocks blastn' + 
                 'We was young and we was dumb but we had heart';
    
    // write to a new file named 2pac.txt
    fs.writeFile('2pac.txt', lyrics, (err) => {
        // throws an error, you could also catch it here
        if (err) throw err;
    
        // success case, the file was saved
        console.log('Lyric saved!');
    });
    

    Especificamos el nombre del archivo, junto con los caracteres a escribir, así como una función de devolución de llamada para ejecutar cuando el método regrese. También podemos pasar un objeto o cadena de opciones que especifique la codificación a usar, así como el modo y la bandera. Si necesita especificar la codificación de caracteres, esta es la forma en que deberá llamar al método:

    fs.writeFile('2pac.txt', 'Some other lyric', 'ascii', callback);
    

    Tenga en cuenta que si el archivo aún no existe, llamar a este método también creará el archivo, por lo que no tiene que preocuparse por eso.

    Hay un método sincrónico fs.writeFileSync que puedes usar en lugar de fs.writeFile.

    La diferencia es que el fs.writeFileSync El método realiza operaciones de entrada / salida de forma sincrónica, bloqueando el bucle de eventos de Node.js mientras se escribe el archivo. Esto puede interferir con el rendimiento de su aplicación Node.js si se excede en estas escrituras sincrónicas. En la mayoría de los casos, debería preferir utilizar las escrituras asincrónicas.

    Solo sepa que debe tener cuidado al usar estos dos métodos porque crearán un nuevo archivo cada vez o reemplazarán el contenido si ya existe. Si simplemente desea actualizar un archivo existente, querrá usar appendFile, que repasaremos más adelante en este artículo.

    Te puede interesar:Cómo corregir: «ADVERTENCIA: LA IDENTIFICACIÓN DEL HOST REMOTO HA CAMBIADO» en Mac y Linux

    Método 2: usar fs.write

    A diferencia del alto nivel fs.writeFile y fs.writeFileSync métodos, puede aprovechar más control al escribir en archivos en Node.js utilizando el nivel bajo fs.write método. los fs.write El método permite un control preciso sobre la posición en el archivo en el que comenzar a escribir, un búfer que puede especificar para escribir, así como la parte del búfer que desea escribir en el archivo.

    Además, el uso de la funcionalidad de escritura de bajo nivel le permite saber con precisión cuándo se publican los descriptores de archivos y responder en consecuencia, como enviando notificaciones automáticas en su aplicación.

    Aquí hay un ejemplo en el que escribimos otras pocas líneas de letra en un archivo diferente usando fs.write.

    // fs_write.js
    
    const fs = require('fs');
    
    // specify the path to the file, and create a buffer with characters we want to write
    let path="ghetto_gospel.txt";
    let buffer = new Buffer('Those who wish to follow menI welcome with my handsnAnd the red sun sinks at last');
    
    // open the file in writing mode, adding a callback function where we do the actual writing
    fs.open(path, 'w', function(err, fd) {
        if (err) {
            throw 'could not open file: ' + err;
        }
    
        // write the contents of the buffer, from position 0 to the end, to the file descriptor returned in opening our file
        fs.write(fd, buffer, 0, buffer.length, null, function(err) {
            if (err) throw 'error writing file: ' + err;
            fs.close(fd, function() {
                console.log('wrote the file successfully');
            });
        });
    });
    

    Querrás usar fs.write al realizar actualizaciones detalladas de archivos, por ejemplo, al escribir una secuencia de bytes en una posición conocida en el medio de un archivo.

    Estos métodos funcionan con descriptores de archivo y debe abrir el archivo para escribir con fs.open y luego, al final, volver a cerrarlo con fs.close para evitar pérdidas de memoria.

    Método 3: usar fs.createWriteStream

    Al manejar archivos particularmente grandes, o archivos que vienen en trozos, digamos desde una conexión de red, usando corrientes es preferible escribir archivos de una sola vez mediante los métodos anteriores que escriben archivos completos.

    Te puede interesar:Cómo Docker puede facilitarle la vida como desarrollador

    Los flujos escriben pequeñas cantidades de datos a la vez. Si bien esto tiene la desventaja de ser más lento porque los datos se transfieren en fragmentos, tiene ventajas para el rendimiento de la RAM. Dado que el archivo completo no se carga en la memoria de una vez, el uso de RAM es menor.

    Para escribir en un archivo mediante secuencias, debe crear una nueva secuencia de escritura. Luego, puede escribir datos en el flujo a intervalos, todos a la vez, o según la disponibilidad de datos de un servidor u otro proceso, luego cerrar el flujo definitivamente una vez que se hayan escrito todos los paquetes de datos.

    Aquí hay un ejemplo de código de cómo hacemos esto:

    // write_stream.js
    
    const fs = require('fs');
    
    let writeStream = fs.createWriteStream('secret.txt');
    
    // write some data with a base64 encoding
    writeStream.write('aef35ghhjdk74hja83ksnfjk888sfsf', 'base64');
    
    // the finish event is emitted when all data has been flushed from the stream
    writeStream.on('finish', () => {
        console.log('wrote all data to file');
    });
    
    // close the stream
    writeStream.end();
    

    Creamos un flujo de escritura y luego escribimos algunos datos en el flujo. Hemos incluido una declaración de registro cuando se emite el evento «fin», que nos informa que todos los datos se han descargado al sistema subyacente. En este caso, eso significa que todos los datos se han escrito en el sistema de archivos.

    Dadas las ventajas de rendimiento, las transmisiones son una técnica que verá que se usa ampliamente en el territorio de Node.js, no solo para la escritura de archivos. Otro ejemplo sería el uso de transmisiones para recibir datos de una conexión de red.

    Manejo de errores al escribir en un archivo

    Al escribir en archivos, pueden ocurrir muchos errores diferentes durante la entrada / salida. Su código debe abordar estos posibles errores. Una cosa simple que puede hacer es lanzar los errores como excepciones de Node.js. Esto bloquea el programa y, por lo tanto, no se recomienda, excepto en los casos en los que tenga pocos otros recursos.

    Te puede interesar:Usar variables globales en Node.js

    Por ejemplo, si el error solo puede ocurrir como un error del programador, también conocido como error, bloquear el programa puede ser la mejor respuesta, ya que alerta al programador del error de inmediato y no lo oculta.

    Cuando se trata de errores operativos, como especificar una ruta que es inaccesible, hay dos enfoques a seguir. Uno es llamar a una función de devolución de llamada con el error. En la devolución de llamada, luego incluye alguna lógica para manejar el error, como registrarlo.

    Alternativamente, puede incluir bloques try / catch alrededor del código llamando a la sección del programa donde pueden ocurrir errores.

    Agregar a un archivo con fs.appendFile

    En los casos en los que solo queremos agregar al contenido de un archivo, podemos usar el fs.appendFile método de alto nivel y su contraparte síncrona, fs.appendFileSync. Utilizando la fs.appendFile crea el archivo si no existe y, en caso contrario, lo agrega al archivo.

    Aquí hay un ejemplo de uso fs.appendFile escribir en un archivo.

    // append_file.js
    
    const fs = require('fs');
    
    // add a line to a lyric file, using appendFile
    fs.appendFile('empirestate.txt', 'nRight there up on Broadway', (err) => {
        if (err) throw err;
        console.log('The lyrics were updated!');
    });
    

    Aquí, estamos usando appendFile para agregar una línea adicional a un archivo que contiene la siguiente letra:

    Te puede interesar:Entrar en el universo de Linux como novato
    // empirestate.txt
    
    Empire State of Mind - JAY-Z
    
    I used to cop in Harlem;
    hola, my Dominicanos
    

    Utilizando fs.appendFile no sobrescribe el archivo, sino que lo actualiza desde la posición final, con los nuevos datos que agregamos. Esta es una característica útil cuando solo desea actualizar un archivo, como agregar continuamente datos a un solo archivo de registro.

    Entonces, después de ejecutar nuestro código, el archivo de texto se verá así:

    // empirestate.txt
    
    Empire State of Mind - JAY-Z
    
    I used to cop in Harlem;
    hola, my Dominicanos
    Right there up on Broadway
    

    Como puede ver, el texto antiguo todavía está allí y nuestra nueva cadena se ha agregado al final.

    Aprende más

    ¿Quiere obtener más información sobre los fundamentos de Node.js? Personalmente, recomendaría tomar un curso en línea como Aprenda Node.js de Wes Bos. No solo aprenderá la sintaxis de ES2017 más actualizada, sino que también podrá crear una aplicación de restaurante completa. En mi experiencia, crear aplicaciones del mundo real como esta es la forma más rápida de aprender.

    Conclusión

    Como vimos, hay varios enfoques a considerar al escribir en un archivo en Node.js. La forma más sencilla, y a menudo la más adecuada, es utilizar el writeFile método en el fs módulo. Esto le permite escribir en una ruta de archivo especificada, con un comportamiento asincrónico, y crea un nuevo archivo o reemplaza uno si existe en la ruta.

    Si está escribiendo archivos más grandes, debe considerar las capacidades de escritura fragmentada de las secuencias de escritura. Estos permiten escribir búferes de datos en fragmentos, en lugar de cargar todos los datos a la vez en la memoria. El uso de transmisiones lo ayuda a lograr un mejor rendimiento en tales casos.

    Te puede interesar:Preguntas de la entrevista sobre la estructura de datos de los gráficos

    Para situaciones especiales, puede utilizar el nivel inferior fs utilidades como fs.write. los fs El módulo admite operaciones de escritura de archivos detalladas para satisfacer sus necesidades específicas.

     

    Rate this post

    Etiquetas: