Apache Commons IO - Guía rápida

La biblioteca Apache Commons IO proporciona varias clases de utilidades para operaciones comunes para File IO que cubren una amplia gama de casos de uso. Ayuda a evitar escribir código repetitivo.

La biblioteca IO de Apache Commons proporciona clases para las siguientes categorías:

Clases de servicios públicos

Estas clases que están bajo org.apache.commons.iopaquete, proporciona comparación de archivos y cadenas. A continuación se muestran algunos de los ejemplos.

  • IOUtils- Proporciona métodos de utilidad para leer, escribir y copiar archivos. Los métodos funcionan con InputStream, OutputStream, Reader y Writer.

  • FilenameUtils- Proporciona un método para trabajar con nombres de archivos sin utilizar File Object. Funciona en diferentes sistemas operativos de manera similar.

  • FileUtils - Proporciona un método para manipular archivos como mover, abrir, verificar la existencia, leer el archivo, etc. Estos métodos utilizan File Object.

  • IOCase - Proporciona un método para la manipulación y comparación de cadenas.

  • FileSystemUtils - Proporciona un método para obtener espacio libre en una unidad de disco.

  • LineIterator - Proporciona una forma flexible de trabajar con un archivo basado en líneas.

Clases de filtro

Las clases de filtro que se encuentran en el paquete org.apache.commons.io.filefilter proporcionan métodos para filtrar archivos basados ​​en criterios lógicos en lugar de tediosas comparaciones basadas en cadenas. A continuación se muestran algunos de los ejemplos.

  • NameFileFilter - Filtra los nombres de archivo por un nombre.

  • WildcardFileFilter - Filtra archivos utilizando los comodines suministrados.

  • SuffixFileFilter- Filtra archivos según el sufijo. Esto se utiliza para recuperar todos los archivos de un tipo particular.

  • PrefixFileFilter - Filtra archivos según el prefijo.

  • OrFileFilter- Proporciona lógica OR condicional a través de una lista de filtros de archivos. Devuelve verdadero, si alguno de los filtros de la lista devuelve verdadero. De lo contrario, devuelve falso.

  • AndFileFilter- Proporciona lógica y condicional a través de una lista de filtros de archivos. Devuelve falso si alguno de los filtros de la lista devuelve falso. De lo contrario, devuelve verdadero.

Clases de Monitor de archivos

Clases de monitor de archivos que están bajo org.apache.commons.io.monitorpaquete, proporciona control para realizar un seguimiento de los cambios en un archivo o carpeta específicos y permite realizar acciones en consecuencia sobre los cambios. A continuación se muestran algunos de los ejemplos.

  • FileEntry- Proporciona el estado de un archivo o directorio. Atributos de archivo en un momento determinado.

  • FileAlterationObserver - Representa el estado de los archivos debajo de un directorio raíz, verifica el sistema de archivos y notifica a los oyentes de eventos de creación, cambio o eliminación.

  • FileAlterationMonitor - Representa un subproceso que genera un subproceso de supervisión que activa cualquier FileAlterationObserver registrado en un intervalo especificado.

Clases de comparación

Clases de supervisor de archivos en org.apache.commons.io.comparator El paquete permite comparar y ordenar archivos y directorios fácilmente.

  • NameFileComparator - Compare los nombres de dos archivos.

  • SizeFileComparator - Compare el tamaño de dos archivos.

  • LastModifiedFileComparator - Compare las últimas fechas de modificación de dos archivos.

Clases de corriente

Hay varias implementaciones de InputStream en el paquete org.apache.commons.io.input y de OutputStream en el paquete org.apache.commons.io.output, para realizar tareas útiles en las transmisiones. A continuación se muestran algunos de los ejemplos.

  • NullOutputStream - Absorbe todos los datos enviados con cualquier error.

  • TeeOutputStream - Envía salida a dos flujos.

  • ByteArrayOutputStream - Versión más rápida de la clase JDK.

  • CountingOutputStream - Cuenta el número de bytes que se pasan a través del flujo.

  • ProxyOutputStream - Cambia las llamadas al flujo de proxy.

  • LockableFileWriter - Un FileWriter para crear archivos de bloqueo y permitir un manejo simple de bloqueo de archivos de subprocesos cruzados.

En este capítulo, aprenderemos acerca de la configuración del entorno local de Apache Commons IO y cómo configurar la ruta de Commons IO para Windows 2000 / XP, Windows 95/98 / ME, etc. También entenderemos acerca de algunos editores Java populares y cómo descargar el archivo Commons IO.

Configuración del entorno local

Si aún está dispuesto a configurar su entorno para el lenguaje de programación Java, esta sección lo guiará sobre cómo descargar y configurar Java en su máquina. Siga los pasos que se mencionan a continuación para configurar el entorno.

Java SE está disponible gratuitamente para descargar en el enlace https://www.oracle.comEntonces descargas una versión basada en tu sistema operativo.

Siga las instrucciones para descargar Java y ejecutar el .exepara instalar Java en su máquina. Una vez que haya instalado Java en su máquina, necesitará establecer variables de entorno para que apunten a los directorios de instalación correctos.

Ruta para Windows 2000 / XP

Entendamos cómo configurar la ruta para Windows 2000 / XP. Suponemos que ha instalado Java enc:\Program Files\java\jdk directorio.

  • Haga clic derecho en 'Mi PC' y seleccione 'Propiedades'.

  • Haga clic en el botón 'Variables de entorno' en la pestaña 'Avanzado'.

  • Ahora, modifique la variable 'Ruta' para que también contenga la ruta al ejecutable de Java. Por ejemplo, si la ruta está configurada actualmente en 'C: \ WINDOWS \ SYSTEM32', cambie su ruta para leer'C:\WINDOWS\SYSTEM32;c:\Program Files\java\jdk\bin'.

Ruta para Windows 95/98 / ME

Entendamos cómo configurar la ruta para Windows 95/98 / ME. Suponemos que ha instalado Java enc:\Program Files\java\jdk directorio.

  • Edite el archivo 'C: \ autoexec.bat' y agregue la siguiente línea al final - 'SET PATH =% PATH%; C: \ Program Files \ java \ jdk \ bin'

Ruta para Linux, UNIX, Solaris, FreeBSD

La variable de entorno PATH debe establecerse para que apunte a dónde se han instalado los binarios de Java. Consulte la documentación de su shell, si tiene problemas para hacer esto.

Por ejemplo, si usa bash como su shell, entonces agregaría la siguiente línea al final de su '.bashrc: export PATH = / path / to / java: $ PATH'

Editores populares de Java

Para escribir sus programas Java, necesita un editor de texto. Hay muchos IDE sofisticados disponibles en el mercado. Pero por ahora, puede considerar uno de los siguientes:

  • Notepad - En una máquina con Windows, puede usar cualquier editor de texto simple como el Bloc de notas (recomendado para este tutorial), TextPad.

  • Netbeans - Es un IDE de Java que es de código abierto y gratuito y que se puede descargar desde https://www.netbeans.org/index.html.

  • Eclipse - También es un IDE de Java desarrollado por la comunidad de código abierto eclipse y se puede descargar desde https://www.eclipse.org/.

Descarga Common IO Archive

Descargue la última versión del archivo jar de Apache Common IO desde commons-io-2.6- bin.zip, que está disponible en download_io.cgi En el momento de escribir este tutorial, hemos descargado commons-io-2.6-bin.zip y copiado en C: \> carpeta Apache.

SO Nombre de archivo
Ventanas commons-io-2.6-bin.zip
Linux commons-io-2.6-bin.tar.gz
Mac commons-io-2.6-bin.tar.gz

Entorno de E / S común de Apache

Selecciona el APACHE_HOMEvariable de entorno para apuntar a la ubicación del directorio base donde, Apache jar se almacena en su máquina. Suponiendo que hemos extraído commons-io-2.6-bin.zip en la carpeta Apache en varios sistemas operativos de la siguiente manera.

SO Salida
Ventanas Establezca la variable de entorno APACHE_HOME en C: \ Apache
Linux exportar APACHE_HOME = / usr / local / Apache
Mac exportar APACHE_HOME = / Library / Apache

Establecer la variable CLASSPATH

Selecciona el CLASSPATHvariable de entorno para apuntar a la ubicación del jar de Common IO. Suponiendo que ha almacenado commons-io-2.6-bin.zip en la carpeta Apache en varios sistemas operativos de la siguiente manera.

SO Salida
Ventanas Establezca la variable de entorno CLASSPATH en% CLASSPATH%;% APACHE_HOME% \ commons-io-2.6.jar;.;
Linux export CLASSPATH = $ CLASSPATH: $ APACHE_HOME / commons-io-2.6.jar :.
Mac export CLASSPATH = $ CLASSPATH: $ APACHE_HOME / commons-io-2.6.jar :.

IOUtils proporciona métodos de utilidad para leer, escribir y copiar archivos. Los métodos funcionan con InputStream, OutputStream, Reader y Writer.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.IOUtils Clase -

public class IOUtils
   extends Object

Características de IOUtils

Las características de IOUtils se dan a continuación:

  • Proporciona métodos de utilidad estáticos para operaciones de entrada / salida.

  • toXXX (): lee datos de una secuencia.

  • write (): escribe datos en una secuencia.

  • copy (): copia todos los datos de una secuencia a otra secuencia.

  • contentEquals: compara el contenido de dos transmisiones.

Ejemplo de clase IOUtils

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import org.apache.commons.io.IOUtils;
public class IOTester {
   public static void main(String[] args) {
      try {
         //Using BufferedReader
         readUsingTraditionalWay();
         //Using IOUtils
         readUsingIOUtils();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   //reading a file using buffered reader line by line
   public static void readUsingTraditionalWay() throws IOException {
      try(BufferedReader bufferReader = new BufferedReader( new InputStreamReader(
      new FileInputStream("input.txt") ) )) {
         String line;
         while( ( line = bufferReader.readLine() ) != null ) {
            System.out.println( line );
         }
      }
   }
   //reading a file using IOUtils in one go
   public static void readUsingIOUtils() throws  IOException {
      try(InputStream in = new FileInputStream("input.txt")) {
         System.out.println( IOUtils.toString( in , "UTF-8") );
      }
   }
}

Salida

Imprimirá el siguiente resultado:

Welcome to TutorialsPoint. Simply Easy Learning.
Welcome to TutorialsPoint. Simply Easy Learning.

FileUtils proporciona un método para manipular archivos como mover, abrir, verificar la existencia, leer el archivo, etc. Estos métodos usan File Object.

Declaración de clase

A continuación se muestra la declaración de la clase org.apache.commons.io.FileUtils:

public class FileUtils
   extends Object

Características de FileUtils

Las características de FileUtils se indican a continuación:

  • Métodos para escribir en un archivo.

  • Métodos para leer de un archivo.

  • Métodos para crear un directorio que incluya directorios principales.

  • Métodos para copiar archivos y directorios.

  • Métodos para eliminar archivos y directorios.

  • Métodos para convertir hacia y desde una URL.

  • Métodos para enumerar archivos y directorios por filtro y extensión.

  • Métodos para comparar el contenido del archivo.

  • Métodos para presentar la fecha del último cambio.

  • Métodos para calcular una suma de comprobación.

Ejemplo de clase FileUtils

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.File;
import java.io.IOException;
import java.nio.charset.Charset;
import org.apache.commons.io.FileUtils;
public class IOTester {
   public static void main(String[] args) {
      try {
         //Using FileUtils
         usingFileUtils();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingFileUtils() throws IOException {
      //get the file object
      File file = FileUtils.getFile("input.txt");
      //get the temp directory
      File tmpDir = FileUtils.getTempDirectory();
      System.out.println(tmpDir.getName());
      //copy file to temp directory
      FileUtils.copyFileToDirectory(file, tmpDir);
      //create a new file
      File newTempFile = FileUtils.getFile(tmpDir, file.getName());
      //get the content
      String data = FileUtils.readFileToString(newTempFile, Charset.defaultCharset());
      //print the content
      System.out.println(data);
   }
}

Salida

La salida se menciona a continuación:

Temp
Welcome to TutorialsPoint. Simply Easy Learning.

FilenameUtils proporciona un método para trabajar con nombres de archivo sin usar File Object. Funciona en diferentes sistemas operativos de manera similar. Esta clase resuelve problemas al pasar de una máquina de desarrollo basada en Windows a una máquina de producción basada en Unix.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.FilenameUtils Clase -

public class FilenameUtils
   extends Object

Características de FileNameUtils

Esta clase define seis componentes dentro de un nombre de archivo. Considere una ubicación de ejemplo comoC:\dev\project\file.txt. Entonces, los componentes son los siguientes:

  • Prefijo - C: \

  • Ruta relativa - dev \ project \

  • Ruta absoluta - C: \ dev \ project \

  • Nombre: archivo.txt

  • Nombre base - archivo

  • Extensión - txt

Para identificar un directorio, agregue un separador al nombre del archivo.

Ejemplo de clase FilenameUtils

El ejemplo de la clase FilenameUtils se da a continuación:

IOTester.java

import java.io.IOException;
import org.apache.commons.io.FilenameUtils;
public class IOTester {
   public static void main(String[] args) {
      try {
         //Using FilenameUtils
         usingFilenameUtils();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingFilenameUtils() throws IOException {
      String path = "C:\\dev\\project\\file.txt";
      System.out.println("Full Path: " +FilenameUtils.getFullPath(path));
      System.out.println("Relative Path: " +FilenameUtils.getPath(path));
      System.out.println("Prefix: " +FilenameUtils.getPrefix(path));
      System.out.println("Extension: " + FilenameUtils.getExtension(path));
      System.out.println("Base: " + FilenameUtils.getBaseName(path));
      System.out.println("Name: " + FilenameUtils.getName(path));
      String filename = "C:/commons/io/../lang/project.xml";
      System.out.println("Normalized Path: " + FilenameUtils.normalize(filename));
   }
}

Salida

La salida se da a continuación:

Full Path: C:\dev\project\
Relative Path: dev\project\
Prefix: C:\
Extension: txt
Base: file
Name: file.txt
Normalized Path: C:\commons\lang\project.xml

FileSystemUtils proporciona un método para obtener el espacio libre en una unidad de disco.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.FileSystemUtils Clase -

public class FileSystemUtils
   extends Object

Ejemplo de clase FileSystemUtils

A continuación se muestra el ejemplo de la clase FileSystemUtils:

IOTester.java

import java.io.IOException;
import org.apache.commons.io.FileSystemUtils;
public class IOTester {
   public static void main(String[] args) {
      try {
         System.out.println("Free Space " + FileSystemUtils.freeSpaceKb("C:/") + " Bytes");
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
}

Salida

A continuación se muestra la salida:

Free Space 61355640 kb

Enumeración de la sensibilidad a mayúsculas y minúsculas de IO. Los diferentes sistemas operativos tienen diferentes reglas para la distinción entre mayúsculas y minúsculas para los nombres de archivo. Por ejemplo, Windows no distingue entre mayúsculas y minúsculas para los nombres de archivos, mientras que Unix distingue entre mayúsculas y minúsculas. IOCase captura esa diferencia, proporciona una enumeración para controlar cómo se deben realizar las comparaciones de nombres de archivos. También proporciona métodos para utilizar la enumeración para realizar comparaciones.

Declaración de enumeración

A continuación se muestra la declaración de org.apache.commons.io.IOCase Enum:

public enum IOCase
   extends Enum<IOCase> implements Serializable

Ejemplo de IOCase Enum

A continuación se da un ejemplo de IOCase Enum:

IOTester.java

import java.io.IOException;
import org.apache.commons.io.IOCase;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingIOCase();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingIOCase() throws IOException {
      String text = "Welcome to TutorialsPoint. Simply Easy Learning.";
      String text1 = "WELCOME TO TUTORIALSPOINT. SIMPLY EASY LEARNING.";
      System.out.println("Ends with Learning (case sensitive): " + IOCase.SENSITIVE.checkEndsWith(text1, "Learning."));
      System.out.println("Ends with Learning (case insensitive): " + IOCase.INSENSITIVE.checkEndsWith(text1, "Learning."));
      System.out.println("Equality Check (case sensitive): " + IOCase.SENSITIVE.checkEquals(text, text1));
      System.out.println("Equality Check (case insensitive): " + IOCase.INSENSITIVE.checkEquals(text, text1));
   }
}

Salida

Imprimirá el siguiente resultado:

Ends with Learning (case sensitive): false
Ends with Learning (case insensitive): true
Equality Check (case sensitive): false
Equality Check (case insensitive): true

LineIterator proporciona una forma flexible de trabajar con un archivo basado en líneas. Aprendamos sobre lo mismo en este capítulo.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.LineIterator Clase -

public class LineIterator
   extends Object implements Iterator<String>, Closeable

Ejemplo de clase LineIterator

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.
Learn web technologies,
prepare exams,
code online,
all at one place.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.LineIterator;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingLineIterator();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingLineIterator() throws IOException {
      //get the file object
      File file = FileUtils.getFile("input.txt");
      try(LineIterator lineIterator = FileUtils.lineIterator(file)) {
         System.out.println("Contents of input.txt");
         while(lineIterator.hasNext()) {
            System.out.println(lineIterator.next());
         }
      }
   }
}

Salida

Imprimirá el siguiente resultado:

Contents of input.txt
Welcome to TutorialsPoint. Simply Easy Learning.
Learn web technologies,
prepare exams,
code online,
all at one place.

NameFileFilter en Commons IO filtra los nombres de archivo para un nombre.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.filefilter.NameFileFilter Clase :

public class NameFileFilter
   extends AbstractFileFilter implements Serializable

Ejemplo de clase NameFileFilter

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

Imprimamos todos los archivos y directorios en el directorio actual y luego, filtremos un archivo cuyo nombre es Input.txt.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.IOCase;
import org.apache.commons.io.filefilter.NameFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingNameFileFilter();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingNameFileFilter() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      //get names of all files and directory in current directory
      String[] files = currentDirectory.list();
      System.out.println("All files and Folders.\n");
      for( int i = 0; i < files.length; i++ ) {
         System.out.println(files[i]);
      }
      System.out.println("\nFile with name input.txt\n");
      String[] acceptedNames = {"input", "input.txt"};
      String[] filesNames = currentDirectory.list( new NameFileFilter(acceptedNames, IOCase.INSENSITIVE) );
      for( int i = 0; i < filesNames.length; i++ ) {
         System.out.println(filesNames[i]);
      }
   }
}

Salida

Imprimirá el siguiente resultado:

All files and Folders.

.classpath
.project
.settings
bin
input.txt
src

File with name input.txt

input.txt

WildcardFileFilter en Commons IO filtra los archivos utilizando los comodines proporcionados.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.filefilter.WildcardFileFilter Clase -

public class WildcardFileFilter
   extends AbstractFileFilter implements Serializable

Ejemplo de clase WildcardFileFilter

Aquí está el archivo de entrada que necesitamos analizar

Welcome to TutorialsPoint. Simply Easy Learning.

Imprimamos todos los archivos y directorios en el directorio actual y luego, filtremos un archivo cuyo nombre termine con t.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.filefilter.WildcardFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingWildcardFileFilter();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingWildcardFileFilter() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      //get names of all files and directory in current directory
      String[] files = currentDirectory.list();
      System.out.println("All files and Folders.\n");
      for( int i = 0; i < files.length; i++ ) {
        System.out.println(files[i]);
      }
      System.out.println("\nFile name ending with t.\n");
      String[] filesNames = currentDirectory.list( new  WildcardFileFilter("*t"));
      for( int i = 0; i < filesNames.length; i++ ) {
        System.out.println(filesNames[i]);
      }
   }
}

Salida

Imprimirá el siguiente resultado.

All files and Folders.

.classpath
.project
.settings
bin
input.txt
src

File name ending with t

.project
input.txt

SuffixFileFilter filtra los archivos que se basan en sufijo. Esto se utiliza para recuperar todos los archivos de un tipo particular.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.filefilter.SuffixFileFilter Clase -

public class SuffixFileFilter
   extends AbstractFileFilter implements Serializable

Ejemplo de clase SuffixFileFilter

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

Imprimamos todos los archivos y directorios en el directorio actual y luego filtremos un archivo con extensión txt.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.filefilter.SuffixFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingSuffixFileFilter();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingSuffixFileFilter() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      //get names of all files and directory in current directory
      String[] files = currentDirectory.list();
      System.out.println("All files and Folders.\n");
      for( int i = 0; i < files.length; i++ ) {
         System.out.println(files[i]);
      }
      System.out.println("\nFile with extenstion txt\n");
      String[] filesNames = currentDirectory.list( new SuffixFileFilter("txt"));
      for( int i = 0; i < filesNames.length; i++ ) {
         System.out.println(filesNames[i]);
      }
   }
}

Salida

Imprimirá el siguiente resultado.

All files and Folders.

.classpath
.project
.settings
bin
input.txt
src

File with extenstion txt

input.txt

PrefixFileFilter filtra los archivos que se basan en el prefijo.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.filefilter.PrefixFileFilter Clase -

public class PrefixFileFilter
   extends AbstractFileFilter implements Serializable

Ejemplo de clase PrefixFileFilter

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

Imprimamos todos los archivos y directorios en el directorio actual y luego, filtremos un archivo cuyo nombre comience con input.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.filefilter.PrefixFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingPrefixFileFilter();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingPrefixFileFilter() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      //get names of all files and directory in current directory
      String[] files = currentDirectory.list();
      System.out.println("All files and Folders.\n");
      for( int i = 0; i < files.length; i++ ) {
         System.out.println(files[i]);
      }
      System.out.println("\nFile starting with input\n");
      String[] filesNames = currentDirectory.list( new PrefixFileFilter("input") );
      for( int i = 0; i < filesNames.length; i++ ) {
         System.out.println(filesNames[i]);
      }
   }
}

Salida

Imprimirá el siguiente resultado:

All files and Folders.

.classpath
.project
.settings
bin
input.txt
src

File with extenstion txt

input.txt

OrFileFilter proporciona lógica OR condicional en una lista de filtros de archivos. Devuelve verdadero, si alguno de los filtros de la lista devuelve verdadero. De lo contrario, devuelve falso.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.filefilter.OrFileFilter Clase -

public class OrFileFilter
   extends AbstractFileFilter implements ConditionalFileFilter, Serializable

Ejemplo de clase OrFileFilter

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

Imprimamos todos los archivos y directorios en el directorio actual y luego, filtremos un archivo cuyo nombre comience con. o termina con t.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.filefilter.OrFileFilter;
import org.apache.commons.io.filefilter.PrefixFileFilter;
import org.apache.commons.io.filefilter.WildcardFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingOrFileFilter();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingOrFileFilter() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      //get names of all files and directory in current directory
      String[] files = currentDirectory.list();
      System.out.println("All files and Folders.\n");
      for( int i = 0; i < files.length; i++ ) {
         System.out.println(files[i]);
      }
      System.out.println("\nFile starting with . or ends with t\n");
      String[] filesNames = currentDirectory.list( new OrFileFilter(new PrefixFileFilter("."), new WildcardFileFilter("*t")));
      for( int i = 0; i < filesNames.length; i++ ) {
         System.out.println(filesNames[i]);
      }
   }
}

Salida

Imprimirá el siguiente resultado.

All files and Folders.

.classpath
.project
.settings
bin
input.txt
src

File starting with . or ends with t

.classpath
.project
.settings
input.txt

AndFileFilter proporciona lógica y condicional en una lista de filtros de archivos. Devuelve verdadero, si todos los filtros de la lista devuelven verdadero. De lo contrario, devuelve falso.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.filefilter.AndFileFilter Clase -

public class AndFileFilter
   extends AbstractFileFilter implements ConditionalFileFilter, Serializable

Ejemplo de clase AndFileFilter

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

Imprimamos todos los archivos y directorios en el directorio actual y luego, filtremos un archivo cuyo nombre comience con. y termina con t.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.filefilter.AndFileFilter;
import org.apache.commons.io.filefilter.PrefixFileFilter;
import org.apache.commons.io.filefilter.WildcardFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingAndFileFilter();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingAndFileFilter() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      //get names of all files and directory in current directory
      String[] files = currentDirectory.list();
      System.out.println("All files and Folders.\n");
      for( int i = 0; i < files.length; i++ ) {
         System.out.println(files[i]);
      }
      System.out.println("\nFile starting with . and ends with t\n");
      String[] filesNames = currentDirectory.list(new AndFileFilter(
         new PrefixFileFilter("."), new WildcardFileFilter("*t")));
      for( int i = 0; i < filesNames.length; i++ ) {
        System.out.println(filesNames[i]);
      }
   }
}

Salida

Imprimirá el siguiente resultado.

All files and Folders.

.classpath
.project
.settings
bin
input.txt
src

File starting with . or ends with t

.project

FileEntry proporciona el estado de un archivo o directorio. Atributos de archivo en un momento determinado.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.monitor.FileEntry Clase -

public class FileEntry
   extends Object implements Serializable

Características de FileEntry

El objeto de clase FileEntry proporciona los siguientes atributos de archivo en un momento determinado.

  • getName (): nombre del archivo.

  • existe (): comprueba si el archivo existe o no.

  • isDirectory (): comprueba si el archivo es un directorio.

  • lastModified (): proporciona la fecha y hora de la última modificación.

  • listFiles (): proporciona el contenido del directorio.

Ejemplo de clase FileEntry

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.monitor.FileEntry;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingFileEntry();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingFileEntry() throws IOException {
      //get the file object
      File file = FileUtils.getFile("input.txt");
      FileEntry fileEntry = new FileEntry(file);
      System.out.println("Monitored File: " + fileEntry.getFile());
      System.out.println("File name: " + fileEntry.getName());
      System.out.println("Is Directory: " + 	fileEntry.isDirectory());
   }
}

Salida

Imprimirá el siguiente resultado.

Monitored File: input.txt
File name: input.txt
Is Directory: false

FileAlterationObserver representa el estado de los archivos debajo de un directorio raíz, verifica el sistema de archivos y notifica a los oyentes sobre eventos de creación, cambio o eliminación.

Declaración de clase

A continuación se muestra la declaración de

org.apache.commons.io.monitor.FileAlterationObserver Clase -

public class FileAlterationObserver
   extends Object implements Serializable

Ejemplo de clase FileAlterationObserver

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileDeleteStrategy;
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.monitor.FileAlterationListenerAdaptor;
import org.apache.commons.io.monitor.FileAlterationMonitor;
import org.apache.commons.io.monitor.FileAlterationObserver;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingFileAlterationObserver();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingFileAlterationObserver() throws IOException {
      //get the file object
      File inputFile = FileUtils.getFile("input.txt");
      String absolutePath = inputFile.getAbsolutePath();
      String parent = absolutePath.substring(0,absolutePath.indexOf("input.txt"));
      File parentDirectory = FileUtils.getFile(parent);
      FileAlterationObserver observer = new
      FileAlterationObserver(parentDirectory);
      observer.addListener(new FileAlterationListenerAdaptor() {
         @Override
         public void onDirectoryCreate(File file) {
            System.out.println("Folder created: " + file.getName());
         }
         @Override
            public void onDirectoryDelete(File file) {
               System.out.println("Folder deleted: " + file.getName());
            }
         @Override
            public void onFileCreate(File file) {
               System.out.println("File created: " + file.getName());
            }
         @Override
            public void onFileDelete(File file) {
               Syst em.out.println("File deleted: " + file.getName());
            }
        });
       //create a monitor to check changes after every 500 ms
       FileAlterationMonitor monitor = new FileAlterationMonitor(500, observer);
       try {
          monitor.start();
         //create a new directory
         File newFolder = new File("test");
         File newFile = new File("test1");
         newFolder.mkdirs();
         Thread.sleep(1000);
         newFile.createNewFile();
         Thread.sleep(1000);
         FileDeleteStrategy.NORMAL.delete(newFolder);
         Thread.sleep(1000);
         FileDeleteStrategy.NORMAL.delete(newFile);
         Thread.sleep(1000);
         monitor.stop(10000);
      } catch(IOException e) {
         System.out.println(e.getMessage());
      } catch(InterruptedException e) {
         System.out.println(e.getMessage());
      } catch (Exception e) {
         System.out.println(e.getMessage());
      }
   }
}

Salida

Imprimirá el siguiente resultado.

Folder created: test
File created: test1
Folder deleted: test
File deleted: test1

FileAlterationMonitor representa un hilo que genera un hilo de supervisión que activa cualquier FileAlterationObserver registrado en un intervalo especificado.

Declaración de clase

A continuación se muestra la declaración de la clase org.apache.commons.io.monitor.FileAlterationMonitor:

public final class FileAlterationMonitor
   extends Object implements Runnable

Ejemplo de clase FileAlterationMonitor

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileDeleteStrategy;
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.monitor.FileAlterationListenerAdaptor;
import org.apache.commons.io.monitor.FileAlterationMonitor;
import org.apache.commons.io.monitor.FileAlterationObserver;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingFileAlterationMonitor();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingFileAlterationMonitor() throws IOException {
      //get the file object
      File inputFile = FileUtils.getFile("input.txt");
      String absolutePath = inputFile.getAbsolutePath();
      String parent = absolutePath.substring(0,absolutePath.indexOf("input.txt"));
      File parentDirectory = FileUtils.getFile(parent);
      FileAlterationObserver observer = new
      FileAlterationObserver(parentDirectory);
      observer.addListener(new FileAlterationListenerAdaptor(){
         @Override
         public void onDirectoryCreate(File file) {
            System.out.println("Folder created: " + file.getName());
         }
         @Override
         public void onDirectoryDelete(File file) {
            System.out.println("Folder deleted: " + file.getName());
         }
         @Override
         public void onFileCreate(File file) {
            System.out.println("File created: " + file.getName());
         }
         @Override
         public void onFileDelete(File file) {
            System.out.println("File deleted: " + file.getName());
         }
      });
      //create a monitor to check changes after every 500 ms
      FileAlterationMonitor monitor = new FileAlterationMonitor(500, observer);
      try {
         monitor.start();
         //create a new directory
         File newFolder = new File("test");
         File newFile = new File("test1");
         newFolder.mkdirs();
         Thread.sleep(1000);
         newFile.createNewFile();
         Thread.sleep(1000);
         FileDeleteStrategy.NORMAL.delete(newFolder);
         Thread.sleep(1000);
         FileDeleteStrategy.NORMAL.delete(newFile);
         Thread.sleep(1000);
         monitor.stop(10000);
      } catch(IOException e) {
         System.out.println(e.getMessage());
      } catch(InterruptedException e) {
         System.out.println(e.getMessage());
      } catch (Exception e) {
         System.out.println(e.getMessage());
      }
   }
}

Salida

Imprimirá el siguiente resultado.

Folder created: test
File created: test1
Folder deleted: test
File deleted: test1

NameFileComparator compara los nombres de dos archivos. Se puede usar para ordenar las listas o matrices de archivos, usando su nombre, ya sea en una forma sensible a mayúsculas, minúsculas o dependiente del sistema.

Declaración de clase

A continuación se muestra la declaración de

org.apache.commons.io.comparator.NameFileComparator Clase -

public class NameFileComparator
   extends Object implements Serializable

Ejemplo de clase NameFileComparator

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.File;
import java.io.FileFilter;
import java.io.IOException;
import org.apache.commons.io.IOCase;
import org.apache.commons.io.comparator.NameFileComparator;
import org.apache.commons.io.filefilter.FileFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingNameFileComparator();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingNameFileComparator() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      NameFileComparator comparator = new
      NameFileComparator(IOCase.INSENSITIVE);
      File[] sortedFiles = comparator.sort(currentDirectory.listFiles((FileFilter)FileFileFilter.FILE));
      System.out.println("Sorted By Name: ");
      for(File file:sortedFiles) {
         System.out.println(file.getName());
      }
   }
}

Salida

Imprimirá el siguiente resultado.

Sorted By Name:
.classpath
.project
input.txt

SizeFileComparator compara los tamaños de dos archivos / directorio. Se puede utilizar para ordenar las listas o matrices de archivos usando su tamaño o directorios, según su número de hijos.

Declaración de clase

A continuación se muestra la declaración de

org.apache.commons.io.comparator.SizeFileComparator Clase -

public class SizeFileComparator
   extends Object implements Serializable

Ejemplo de clase SizeFileComparator

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.File;
import java.io.FileFilter;
import java.io.IOException;
import org.apache.commons.io.comparator.SizeFileComparator;
import org.apache.commons.io.filefilter.FileFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingSizeFileComparator();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   } 
   public static void usingSizeFileComparator() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      SizeFileComparator comparator = new SizeFileComparator();
      File[] sortedFiles = comparator.sort(currentDirectory.listFiles((FileFilter)FileFileFilter.FILE));
      System.out.println("Sorted By Size: ");
      for(File file:sortedFiles) {
         System.out.println(file.getName() + ", size(kb) :" + file.length());
      }
   }
}

Salida

Imprimirá el siguiente resultado.

Sorted By Size:
input.txt, size:124
.project, size:382
.classpath, size:441

LastModifiedFileComparator compara las últimas fechas de modificación de dos archivos / directorio. Se puede utilizar para ordenar las listas o matrices de archivos / directorios utilizando sus últimas fechas de modificación.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.comparator.LastModifiedFileComparator Clase -

public class LastModifiedFileComparator
   extends Object implements Serializable

Ejemplo de clase LastModifiedFileComparator

Aquí está el archivo de entrada que necesitamos analizar:

Welcome to TutorialsPoint. Simply Easy Learning.

IOTester.java

import java.io.File;
import java.io.FileFilter;
import java.io.IOException;
import java.util.Date;
import org.apache.commons.io.comparator.LastModifiedFileComparator;
import org.apache.commons.io.filefilter.FileFileFilter;
public class IOTester {
   public static void main(String[] args) {
      try {
         usingLastModifiedFileComparator();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingLastModifiedFileComparator() throws IOException {
      //get the current directory
      File currentDirectory = new File(".");
      LastModifiedFileComparator comparator = new LastModifiedFileComparator();
      File[] sortedFiles = comparator.sort(currentDirectory.listFiles((FileFilter)FileFileFilter.FILE));
      System.out.println("Sorted By Last Modified date: ");
      for(File file:sortedFiles) {
         System.out.println(file.getName() + ", Modified on: " + new Date(file.lastModified()));
      }
   }
}

Salida

Imprimirá el siguiente resultado.

Sorted By Last Modified date:
.project, Modified on: Thu Oct 12 19:06:45 IST 2017
.classpath, Modified on: Mon Nov 20 13:09:55 IST 2017
input.txt, Modified on: Mon Nov 20 19:27:55 IST 2017

Es un proxy InputStream que escribe de forma transparente una copia de todos los bytes que se leen del flujo del proxy en un OutputStream determinado. El flujo de entrada del proxy se cierra cuando se llama al método close () en este proxy. Se puede utilizar para operar dos flujos de forma colectiva a la vez.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.input.TeeInputStream Clase -

public class TeeInputStream
   extends ProxyInputStream

Ejemplo de clase TeeInputStream

En este ejemplo, al cerrar un TeeInputStream, se cierran los objetos TeeInputStream y TeeOutputStream.

IOTester.java

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import org.apache.commons.io.input.TeeInputStream;
import org.apache.commons.io.output.TeeOutputStream;
public class IOTester {
   private static final String SAMPLE = "Welcome to TutorialsPoint. Simply Easy
   Learning.";
   public static void main(String[] args) {
      try {
         usingTeeInputStream();
      }catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingTeeInputStream() throws IOException {
      TeeInputStream teeInputStream = null;
      TeeOutputStream teeOutputStream = null;
      try {
         ByteArrayInputStream inputStream = new
         ByteArrayInputStream(SAMPLE.getBytes("US-ASCII"));
         ByteArrayOutputStream outputStream1 = new ByteArrayOutputStream();
         ByteArrayOutputStream outputStream2 = new ByteArrayOutputStream();
         teeOutputStream = new TeeOutputStream(outputStream1, outputStream2);
         teeInputStream = new TeeInputStream(inputStream, teeOutputStream, true);
         teeInputStream.read(new byte[SAMPLE.length()]);
         System.out.println("Output stream 1: " + outputStream1.toString());
         System.out.println("Output stream 2: " + outputStream2.toString());
      }catch (IOException e) {
         System.out.println(e.getMessage());
      } finally {
         //teeIn.close() closes teeIn and teeOut which in turn closes the out1 and out2.
         try {
            teeInputStream.close();
         } catch (IOException e) {
            System.out.println(e.getMessage());
         }
      }
   }
}

Salida

Imprimirá el siguiente resultado.

Output stream 1: Welcome to TutorialsPoint. Simply Easy Learning.
Output stream 2: Welcome to TutorialsPoint. Simply Easy Learning.

TeeOutputStream divide el OutputStream. Lleva el nombre del comando 'tee' de Unix. Permite que una corriente se ramifique en dos corrientes.

Declaración de clase

A continuación se muestra la declaración de org.apache.commons.io.output.TeeOutputStream Clase -

public class TeeOutputStream
   extends ProxyOutputStream

Ejemplo de clase TeeOutputStream

En este ejemplo, TeeOutputStream acepta dos flujos de salida como parámetro y pasa datos a TeeOutputStream establece datos a ambos flujos de salida.

IOTester.java

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import org.apache.commons.io.input.TeeInputStream;
import org.apache.commons.io.output.TeeOutputStream;
public class IOTester {
   private static final String SAMPLE = "Welcome to TutorialsPoint. Simply Easy
   Learning.";
   public static void main(String[] args) {
      try {
         usingTeeInputStream();
      } catch(IOException e) {
         System.out.println(e.getMessage());
      }
   }
   public static void usingTeeInputStream() throws IOException {
      TeeInputStream teeInputStream = null;
      TeeOutputStream teeOutputStream = null;
      try {
         ByteArrayInputStream inputStream = new
         ByteArrayInputStream(SAMPLE.getBytes("US-ASCII"));
         ByteArrayOutputStream outputStream1 = new ByteArrayOutputStream();
         ByteArrayOutputStream outputStream2 = new ByteArrayOutputStream();
         teeOutputStream = new TeeOutputStream(outputStream1, outputStream2);
         teeInputStream = new TeeInputStream(inputStream, teeOutputStream, true);
         teeInputStream.read(new byte[SAMPLE.length()]);
         System.out.println("Output stream 1: " + outputStream1.toString());
         System.out.println("Output stream 2: " + outputStream2.toString());
      } catch (IOException e) {
         System.out.println(e.getMessage());
      } finally {
         //teeIn.close() closes teeIn and teeOut which in turn closes the out1 and out2.
         try {
            teeInputStream.close();
         } catch (IOException e) {
            System.out.println(e.getMessage());
         }
      }
   }
}

Salida

Imprimirá el siguiente resultado.

Output stream 1: Welcome to TutorialsPoint. Simply Easy Learning.
Output stream 2: Welcome to TutorialsPoint. Simply Easy Learning.