File - Schule.at

Werbung
Dateien
Die Klasse File
Die Klasse File stellt die Verbindung zwischen dem Filesystem
des Rechners und dem JAVA-Programm her.
Das Filesystem enthält als Objekte Devices, Verzeichnisse und
Dateien. Sie werden durch ihre Namen eindeutig gekennzeichnet.
Die Klasse File:
– Bildet Objekte des Filesystems auf Instanzen der Klasse File
ab.
– Stellt die Verbindung zwischen Datei und Dateinamen her.
– Ermöglicht das Lesen von Verzeichnissen.
– Ermöglicht das Lesen von Attributen von Dateien und
Verzeichnissen.
– Ermöglicht das Erzeugen, Löschen, Umbenennen und
Modifizieren von Dateien und Verzeichnissen.
– Stellt eine vom Betriebsystem unabhängige Schnittstelle zur
Verfügung.
Attribute der Klasse File
static String pathSeparator
– liefert die Zeichenkette, die Pfadeinträge im PATH trennt
– UNIX : ":"
– WINDOWS: ";"
static char pathSeparatorChar
– das gleiche als Zeichen
static String separator
– liefert die Zeichenkette, die Verzeichnisse im Pfad trennt
– UNIX : "/"
– WINDOWS: "\\"
static char separatorChar
– das gleiche als Zeichen
Konstruktoren der Klasse File
File (String pathname)
– erzeugt ein File-Objekt mit pathname als Pfad
File (String parent, String child)
– erzeugt ein File-Objekt mit einem Pfad child ggf. relativ zu
parent
File (File parent, String child)
Konstruktoren öffnen die Dateien nicht! Es erfolgt
kein Zugriff zum Filesystems.
Statische Methoden der Klasse File
static
String
static
String
File createTempFile(String prefix,
suffix, File directory)
File createTempFile(String prefix,
suffix)
– erzeugen temporäres File mit dem Namen:
prefix....suffix im Standard-Verzeichnis für temporäre
Dateien bzw. im Verzeichnis directory
static File [] listRoots()
– erzeugt ein Feld von File-Objekten, die auf die
Wurzelverzeichnisse zeigen, z.B.: Windows:
A:\
C:\
D:\
Methoden der Klasse File
boolean canRead() // Test ob Datei lesbar ist
boolean canWrite() // Test ob Datei schreibbar ist
boolean exists() // Test ob Datei existiert
boolean isAbsolute() // Test ob Pfad absolut ist
boolean isDirectory() // Test ob File ein Verzeichnis ist
boolean isFile() // Test ob File eine Datei ist
boolean isHidden() // Test ob Datei versteckt ist
long lastModified() // Zeit der letzten Modifikation in
Millisekunden seit 1.1.1970 0.00 GMT
boolean setLastModified(long time) // setzt Zeit der
letzten Modifikation
boolean setReadOnly() // setzt das File auf ReadOnly
int compareTo(File pathname)
vergleicht die Pfadnamen unter Berücksichtigung der Eigenschaften
des Filesystems (z.B.: Groß- und Kleinschreibung)
– f1.compareTo(f2) == 0 wenn Pfadnamen gleich
– f1.compareTo(f2) < 0 wenn Pfadnamen von f1 vor f2
– f1.compareTo(f2) > 0 wenn Pfadnamen von f1 nach f2
int compareTo(Object o)
File implementiert Comparable
boolean equals (Object o)
– f1.equals(f2) == true wenn Pfadnamen gleich
boolean createNewFile() // erzeugt eine neue leere Datei,
falls sie noch nicht existiert
boolean delete() // löscht das File
void deleteOnExit() // löscht das File nach dem Ende des
Programms
boolean mkdir() // erzeugt ein neues Verzeichnis
boolean mkdirs() // erzeugt ein neues Verzeichnis incl. aller
erforderlichen Zwischenverzeichnisse
boolean renameTo(File dest) // benennt eine Datei um
File getAbsoluteFile() // gibt das File mit absolutem
Pfadnamen aus
String getAbsolutePath() // gibt den absoluten Filenamen
aus
File getCanonicalFile() // gibt das File mit kanonischem
Pfadnamen aus
String getCanonicalPath()
String getName() // gibt den evtl. relativen Filenamen aus
String getParent() // gibt das Elternverzeichnis aus
File getParentFile()
String getPath()
long length() // gibt die Länge der Datei aus
String toString() // wie getName()
URL toURL() // gibt den Filenamen in Form eines URLs aus
int hashCode()
String [] list() // gibt eine Liste aller in der Datei
enthaltenen Dateien und Unterverzeichnisse aus
String [] list(FilenameFilter filter)
File [] listFiles()
File [] listFiles(FileFilter filter)
File [] listFiles(FilenameFilter filter)
Das Interface FileFilter
Mit Hilfe einer Implementation des Interfaces FileFilter kann in
der listFiles-Methode der Klasse File eine Auswahl der
auszugebenden File-Objekte getroffen werde.
Einzige zu implementierende Methode:
public boolean accept(File pathname)
gibt true zurück, wenn das File-Objekt ausgewählt werden soll und
false sonst
Das Interface FileNameFilter
Mit Hilfe einer Implementation des Interfaces FileNameFilter
kann in der list- und der listFiles-Methode der Klasse File eine
Auswahl der auszugebenden File-Objekte getroffen werde.
Einzige zu implementierende Methode:
public boolean accept(File dir, String name)
gibt true zurück, wenn das File-Objekt ausgewählt werden soll und
false sonst
Beispiel: Verzeichnisinhalt anzeigen
import java.io.*;
public class Dir {
public static void main (String [] args) throws IOException
{
String dName = (args.length>0?args[0]:".");
File d = new File(dName);
if ( d.exists() ) {
file(d);
if (d.isDirectory()) dir(d);
}
else
System.err.println("File "+dName+" existiert nicht!");
}
static void file(File d) {
System.out.println((d.canRead()?"R":" ")+
(d.canWrite()?"W":" ")+
(d.isHidden()?"H":" ")+(d.isDirectory()?"D":"")+
(d.isFile()?"F":"")+" : "+d.length()+"\t"+
" : "+(new java.util.Date(d.lastModified()))+" : "+d);
}
static void dir(File d){
System.out.println("Verzeichnis : "+d);
File [] files = d.listFiles();
for (int i=0;i<files.length;i++) file(files[i]);
for (int i=0;i<files.length;i++)
if (files[i].isDirectory()) dir(files[i]);
}
}
Beispiel: Verzeichnisinhalt mit Filter anzeigen
import java.io.*;
public class DirF {
public static void main (String [] args) throws IOException
{
String dName = (args.length>0?args[0]:".");
File d = new File(dName);
Filter fil = (args.length>1?new Filter(args[1]):null);
if ( d.exists() ) {
file(d);
if (d.isDirectory()) dir(d, fil);
}
else
System.err.println("File "+dName+" existiert nicht!");
}
static void file(File d) {
System.out.println((d.canRead()?"R":" ")+
(d.canWrite()?"W":" ")+
(d.isHidden()?"H":" ")+(d.isDirectory()?"D":"")+
(d.isFile()?"F":"")+" : "+d.length()+"\t"+
" : "+(new java.util.Date(d.lastModified()))+" : "+d);
}
static void dir(File d, Filter fil){
System.out.println("Verzeichnis : "+d);
File [] files = d.listFiles(fil);
for (int i=0;i<files.length;i++) file(files[i]);
for (int i=0;i<files.length;i++)
if (files[i].isDirectory()) dir(files[i], fil);
}
static class Filter implements FileFilter {
private String match;
Filter (String match) {
this.match=match;
}
public boolean accept (File f) {
if (f.isDirectory()) return true;
try {
return f.getCanonicalPath().indexOf(match)>=0;
}
catch (Exception e) {}
return false;
}
}
}
Herunterladen