Manejo de archivos con JSP
La función readFile, dado un nombre de archivo (con el "camino" incluido. Ej. D:\files\prueba.txt), devuelve un objeto de tipo StringBuffer con el contendio del mismo.
- El método saveFile , toma como primer parámetro el nombre del archivo que se desea generar o modificar, el segundo parámetro es el contenido que se desea introducir en dicho archivo. En fin el tercer parámetro es una variable de tipo boolean, que si recibe el valor "true" , aprega la información recibida al final del archivo (si este archivo existe). Si, en cambio, recibe "false" como parametro, borra el contenido del actual del archivo y lo reemplaza con el segundo parametro.
- Finalmente la tercera función 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 podría 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 continuación el código 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>
*
* <p>Copyright: Copyright (c) 2006</p>
*
* @author Fernando Arturi
* @version 1.0
*/
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{
/**
* Aqui 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 lineas del
* archivo de texto
*/
String line = null;
/**
* BufferReader - Es el encargado de leer el archivo de texto.
* El constructor recibe como parametro un objeto FileReader, que
* a s vez recibe el objeto File creado precedentemente.
*/
BufferedReader br = new BufferedReader(new FileReader(file));
/**
* A traves 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 automaticamente un error.
*/
System.out.println("No ha sido posible encontrar el archivo "+ filename);
}
catch (IOException ioe){
/**
* Se ha producido un error durante lalectura 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 {
/**
* Creaciòn del objeto FileWriter dado un nombre de archivo determinado
* El segundo parametro (append) contiene un valore booleano que
* indica si la informacion recibida debe ser agregada el final del
* archivo o, en caso contrario, reemplazar la informaciòn ya
* existente.
*/
FileWriter fw = new FileWriter(filename, append);
/**
* Escritura de la informacion 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 funcion permite, dado un archivo en particular, buscar dentro el mismo
* determinados valures 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 automaticamente 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
* bùsqueda 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);
/**
* busqueda y reemplazo de la cadena.
*/
tempText = tempText + valuesToReplace[i] + textComplete.substring(position+valuesToSearch[i].length(),textComplete.length());
textComplete = new StringBuffer(tempText);
}
}
return tempText;
}
}