Manejo de Archivos Con JSP
Manejo de Archivos Con JSP
Manejo de Archivos Con JSP
Se explicar bsicamente la lectura, modificacin y escritura de archivos de texto. Para esto construiremos la clase FileManager que, a travs de sus mtodos, permitir ejecutar dichas operaciones.
La funcin readFile, dado un nombre de archivo (con la "direccin" incluida. Ej. D:\files\prueba.txt), devuelve un objeto de tipo StringBuffer con el contendio del mismo. El mtodo saveFile , toma como primer parmetro el nombre del archivo que se desea generar o modificar, el segundo parmetro es el contenido que se desea introducir en dicho archivo. En fin el tercer parmetro es una variable de tipo boolean, que si recibe el valor "true", agrega la informacin recibida al final del archivo (si este archivo existe). Si, en cambio, recibe "false" como parmetro, borra el contenido del actual del archivo y lo reemplaza con el segundo parmetro. Finalmente la tercera funcin sirve para buscar uno o mas valores dentro de un archivo de una cadena de texto y reemplazarlos por una serie de valores dados.
Por ejemplo se podra usar de este modo: String[] busqueda = {"NOMBRE","APELLIDO"}; String[] reemplazo = {"FERNANDO","ARTURI"}; FileManager fm = new FileManager(); String resultado = fm.replaceValues("D:\myFiles\prueba.txt", busqueda, reemplazo); A continuacin el cdigo de la classe: package notas; import java.io.File; import java.io.FileReader; import java.io.FileWriter; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOException; import java.io.FileNotFoundException; /* * <p>Title: FileManager</p> * <p>Description: Manejo de archivos de texto</p> */ public class FileManager { public void FileManager(){} /** * El metodo readFile lee un archivo de texto y retorna su contenido en formato de StringBuffer * @param filename String * @return StringBuffer
*/ public StringBuffer readFile(String filename){ StringBuffer sb = new StringBuffer(); try{ /** Aqu creamos un objeto File que representa el archivo de texto que queremos leer */ File file = new File(filename); /** * Variable temporal que usaremos para leer cada una de las lneas del archivo de texto */ String line = null; /** * BufferReader - Es el encargado de leer el archivo de texto. * El constructor recibe como parmetro un objeto FileReader, que a su vez recibe el objeto File creado precedentemente. */ BufferedReader br = new BufferedReader(new FileReader(file)); /** * A travs de este ciclo el BufferReader lee todo el archivo, y lo va acumulando (sb.append) en un StringBuffer */ while ((line = br.readLine()) != null) { sb.append(line); } /** * Al final de la lectura cerramos el objeto */ br.close(); } catch (FileNotFoundException fnfe){ /** * Si damos un nombre de archivo que no existe el sistema genera automticamente un error. */ System.out.println("No ha sido posible encontrar el archivo "+ filename); } catch (IOException ioe){ /** * Se ha producido un error durante la lectura del archivo */ System.out.println("Se ha producido un error durante la lectura del archivo "+ filename); } return sb; }
/** * Este metodo permite, dada una cadena de caracteres determinada, salvar la misma como un archivo de texto, o agregarla a un archivo ya existente * @param filename String * @param dataToWrite String * @param append boolean */ public void saveFile(String filename, String dataToWrite, boolean append) { try { /** * Creacin del objeto FileWriter dado un nombre de archivo determinado * El segundo parmetro (append) contiene un valore booleano que indica si la informacin recibida debe ser agregada el final del archivo o, en caso contrario, reemplazar la informacin ya existente. */ FileWriter fw = new FileWriter(filename, append); /** * Escritura de la informacin en el archivo */ fw.write(dataToWrite); /** * Se cierra el archivo */ fw.close(); } catch (IOException ioe) { /** * Se ha producido un error durante la lectura/escritura del archivo */ System.out.println( "Se ha producido un error durante la lectura del archivo " + filename); } }
/** * Esta funcin permite, dado un archivo en particular, buscar dentro el mismo determinados valores y cambiarlos por una serie de nuevos valores dados, generando un objeto de tipo String con el resultado * * @param path String * @param valuesToSearch String[] Ejemplo {"NOMRE", "APELLIDO"} * @param valuesToReplace String[] Ejemplo {"Fernando Augusto", "Arturi"} * @return String */ public String replaceValues (String path, String [] valuesToSearch, String [] valuesToReplace){ String line; StringBuffer textComplete = new StringBuffer(); String tempText = ""; /** * Lectura del archivo de texto dado
*/ try { BufferedReader br = new BufferedReader(new FileReader(path)); while ((line = br.readLine()) != null){ textComplete.append(line); } br.close(); } catch (FileNotFoundException fnfe){ /** * Si damos un nombre de archivo que no existe el sistema genera automticamente un error. */ System.out.println("No ha sido posible encontrar el archivo "+ filename); } catch (IOException ioe) { /** * Se ha producido un error durante la lectura/escritura del archivo */ System.out.println( "Se ha producido un error durante la lectura del archivo " + filename); } /** * Una vez completada la fase de lectura del archivo, pasamos a la bsqueda y reemplazo de los valores datos. Para esto generamos un ciclo que recorremos tantas veces como valores que tenemos que procesar. */ for (int i=0; i<valuesToSearch.length; i++){ int position = textComplete.indexOf(valuesToSearch[i]); if (position>0 ){ tempText = textComplete.substring(0,position); /** * bsqueda y reemplazo de la cadena. */ tempText = tempText + valuesToReplace[i] + textComplete.substring(position+valuesToSearch[i].length(),textComplete.length()); textComplete = new StringBuffer(tempText); } } return tempText; } }