system.out und system.err einer Methode in Datei schreiben.

Status
Nicht offen für weitere Antworten.

sunfy

Mitglied
Hallo,
ich versuche gerade die Ausgaben einer Methode in Dateien zu schreiben.
Folgendes habe ich mir überlegt:
ich rufe die methode auf, in der mit
Code:
system.out.println("blah sysout");
system.err.println("ganz viele Errors");
etwas in die Console geschrieben wird.
Jetzt möchte ich halt nur nicht, das es in der Console landet, sondern es mit catch abfangen und in eine Textdatei schreiben.

Code:
try {
	methode(parameter);
} catch (??? syserr) {
	writeToFile("errors.txt", syserr.toString() );
} catch(??? sysout){
	writeToFile("sysouts.txt", sysout.toString() );
}

hat da jemand eine Idee, wie man das machen könnte?
(was genau man abfangen muss?

Gruß Sunfy
 
S

SlaterB

Gast
vor der Operation
System.setOut(myPrintStream);
aufrufen

setzt voraus, dass du dich mit Streams usw. auskennst

Web-Suche nach 'java system.out umleiten' liefert viel, z.B.

http://support.microsoft.com/kb/252021/de

Code:
            PrintStream ps = new PrintStream(
                             new BufferedOutputStream(new FileOutputStream(
                             new File("javalog.txt"))), true);
            System.setOut(ps);         
            System.setErr(ps);
 

Murray

Top Contributor
Mit try-catch kann man nur Throwables abfangen. Was du brauchst, ist eine Ausgabeumleitung. Das geht mit System#setOut und System#setErr.

//EDIT: da war der Slater wieder schneller...
 

sunfy

Mitglied
Na das war ja mal ne schnelle Antwort.
Das klappt jetzt auch soweit.

Ich muss jetzt nur noch herausfinden, wie ich die Umleitung des sys.err und sys.out nach dem try-Block wieder in die Console ausgeben lasse.

Code:
try 
	    {
	    	PrintStream psOut = new PrintStream(
	    			new BufferedOutputStream(new FileOutputStream(
	    					new File("tmp","out.txt"))), true);
	    	System.setOut(psOut);
	    	
	    	PrintStream psErr = new PrintStream(
	    			new BufferedOutputStream(new FileOutputStream(new File("tmp","err.txt"))), true);
	    	System.setErr(psErr); 
	    	
	    	writeErrors();
	    } 
	    catch (Exception e)
	    {
	    	System.out.println(e.getMessage());
	    }
 
S

SlaterB

Gast
bisschen denken:

ein Tipp:
PrintStream oldOut = System.out;
 

sunfy

Mitglied
ja, soweit hatte ich eben auch schon gedacht.
Allerdings werden die syserr und sysout nach dem try block immernoch in die Datei geschrieben.

Code:
try 
	    {
	    	PrintStream psOut = new PrintStream(
	    			new BufferedOutputStream(new FileOutputStream(
	    					new File("tmp","out.txt"))), true);
	    	System.setOut(psOut);
	    	
	    	PrintStream psErr = new PrintStream(
	    			new BufferedOutputStream(new FileOutputStream(new File("tmp","err.txt"))), true);
	    	System.setErr(psErr); 
	    	
	    	writeErrors();
	    	
	    	PrintStream outStream = System.out; 
	    	System.setOut(outStream);
	    	
	    	PrintStream errStream = System.err;
	    	System.setErr(errStream);
	    } 
	    catch (Exception e)
	    {
	    	System.out.println(e.getMessage());
	    }	
		System.out.println("es klappt mit out");
		System.err.println("es klappt mit err");
 

sunfy

Mitglied
aja stimmt.

jetzt gehts.
danke für die schnelle Hilfe. :)
gruß Sunfy

Code:
try 
	    {
	    	PrintStream oldOut = System.out; 
	    	PrintStream psOut = new PrintStream(
	    			new BufferedOutputStream(new FileOutputStream(
	    					new File("tmp","out.txt"))), true);
	    	System.setOut(psOut);

	    	PrintStream oldErr = System.err;
	    	PrintStream psErr = new PrintStream(
	    			new BufferedOutputStream(new FileOutputStream(
	    					new File("tmp","err.txt"))), true);
	    	System.setErr(psErr); 

	    	writeErrors();


	    	System.setOut(oldOut);
	    	System.setErr(oldErr);
	    } 
	    catch (Exception e)
	    {
	    	System.out.println(e.getMessage());
	    }
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
X Input/Output InputStream/Scanner(System.in) read()/hasNextLine() block unterbrechen Allgemeine Java-Themen 7
P9cman java.Lang Klassen fehlen in JRE System Library Allgemeine Java-Themen 1
B Lottospielen mit System, Versuch 2, noch umständlicher als vorher Allgemeine Java-Themen 1
J Frage zu System.getproperties. Allgemeine Java-Themen 60
sascha-sphw Erste Schritte Unit und Integration-Tests im Java Modul System Allgemeine Java-Themen 10
F Frage zu System.in Allgemeine Java-Themen 3
E System property setzten Allgemeine Java-Themen 8
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
O Beziehung System.exit(x) <>Errorlevel Allgemeine Java-Themen 2
B System.out Ausgabe auf jtextarea Fehlersuche Allgemeine Java-Themen 8
F System Tray Menubutton ActionListener Allgemeine Java-Themen 5
H Im Tiled-Map-System ein Item anklicken Allgemeine Java-Themen 0
S Java Plugin System (ohne OSGI) Allgemeine Java-Themen 10
D System.arraycopy verhält sich seltsam Allgemeine Java-Themen 1
C Login System Allgemeine Java-Themen 19
A BufferedReader ohne System.in Allgemeine Java-Themen 9
VfL_Freak JDK installieren System-Property "user.dir" Allgemeine Java-Themen 6
J System.arraycopy ergibt anderes Resultat als for-loop Allgemeine Java-Themen 4
F Wie kann ich auf einem System prüfen, ob eine lib verfügbar ist? Allgemeine Java-Themen 2
D Java System.out::println Allgemeine Java-Themen 1
D Methoden Java Applikation Die System Auslastung optimieren ? Allgemeine Java-Themen 7
S Ist Java ein geschlossenes System? Allgemeine Java-Themen 2
L Erste Schritte Suche Java Wiki System? Allgemeine Java-Themen 5
chuxXo System/JLayer Volume ändern Allgemeine Java-Themen 0
Neumi5694 System.out und System.err umleiten - NICHT im Quelltext Allgemeine Java-Themen 4
X System.out/err(Die Console) in JTextArea ausgeben Allgemeine Java-Themen 2
S Best Practice System.arrayCopy verändert Ziel-Array Allgemeine Java-Themen 2
A Methoden Der Sinn von system.out.print(); Allgemeine Java-Themen 9
A System freezes when trying to run external command from Java with wait for Allgemeine Java-Themen 3
A Java | Login-System Allgemeine Java-Themen 3
C System.out.print("") Compiler Fehler Allgemeine Java-Themen 2
Joew0815 Best Practice Wie am besten Plugin-System erstellen? Allgemeine Java-Themen 12
C System.in erhält Input von Tastatur. wo wird das festgelegt? Allgemeine Java-Themen 4
F Benachrichtigungs-System Webapp Java Servlet Allgemeine Java-Themen 10
M collection persistence system Allgemeine Java-Themen 4
V System.out.println an jeder Stelle im Projekt löschen Allgemeine Java-Themen 4
D System.out's in String speichern. Allgemeine Java-Themen 2
H Interpreter-Fehler ArrayIndexOutOfBoundsException bei System.arraycopy() Allgemeine Java-Themen 3
M System herausfinden Allgemeine Java-Themen 6
O Variablen System.getenv: Sinnlose Werte, Arrays?! Allgemeine Java-Themen 6
G java.exe in System 32. Hilfe!!! Allgemeine Java-Themen 8
R Methoden Tag System Problem Allgemeine Java-Themen 3
J System.out im GUI anzeigen Allgemeine Java-Themen 3
N System.exit(0/1) Allgemeine Java-Themen 3
F System.out.println mit log4j ersetzen Allgemeine Java-Themen 10
D System.LoadLibrary(..) - Programm stürzt ab Allgemeine Java-Themen 2
U Classpath DLLs mittels System.load() laden: Allgemeine Java-Themen 6
D Listener auf System.out.err / System.out.println Allgemeine Java-Themen 5
G Input/Output System.in "umbiegen" für junit-Test Allgemeine Java-Themen 4
Kr0e User management system Allgemeine Java-Themen 2
S Java Programm -System Neustart überleben? Allgemeine Java-Themen 3
Rudolf Wann System.exit und wann dispose? Allgemeine Java-Themen 9
ruutaiokwu System.out auf files umlenken in log4j.xml Allgemeine Java-Themen 4
K Objekt-Austausch zwischen zwei Programmen über System-Clipboard Allgemeine Java-Themen 5
agent47 Plugin System Verständnisfrage Allgemeine Java-Themen 6
M Wie externe System-Ressourcen zwangsweise freigeben Allgemeine Java-Themen 2
E Durch System.in.read() blockierten Thread stoppen Allgemeine Java-Themen 10
P System.out im Eclipse plugin Allgemeine Java-Themen 4
C File System Watcher Allgemeine Java-Themen 2
S Verhalten von System.getenv() in Ubuntu / Linux Allgemeine Java-Themen 12
A Problem mit System.getProperty(...) Allgemeine Java-Themen 5
D System.loadlibrary funktioniert nicht Allgemeine Java-Themen 6
H Event ähnliches System Allgemeine Java-Themen 20
Dissi Gammawerte des Grafiktreibers / System ändern? Allgemeine Java-Themen 3
M Plugin-System Allgemeine Java-Themen 4
A NullPointer bei System.getProperty("file.seperator") Allgemeine Java-Themen 4
R System.out oder System.err? Allgemeine Java-Themen 10
M Wie kann ich alle System.out Strings in ein log window umleiten? Allgemeine Java-Themen 6
K System.exec() Programm mit mehreren Parametern Allgemeine Java-Themen 8
G unerklärliches System.out Allgemeine Java-Themen 3
M System.setProperty("javax.net.ssl.trustStore", "mykey.pkx"); Allgemeine Java-Themen 1
T System Preferences + LInux (Ubuntu) Allgemeine Java-Themen 8
G OutputStream to System.out Allgemeine Java-Themen 35
J Wo werden die System properties gespeichert Allgemeine Java-Themen 12
C JSR295 in Produktiven System zu empfehlen? Allgemeine Java-Themen 3
B System CPU Zeit / Last auslesen Allgemeine Java-Themen 2
G Bringt es etwas System.gc() nach großen Aufgaben aufzurufen? Allgemeine Java-Themen 2
T Feststellen ob System-Konsole verfügbar Allgemeine Java-Themen 2
L remote debugging of a multi threaded system Allgemeine Java-Themen 2
F Probleme mit eigenem Plugin-System Allgemeine Java-Themen 3
L System.exit Allgemeine Java-Themen 3
G System.out und String machen was anderes Allgemeine Java-Themen 5
G System.out im window h.inein bringen? Allgemeine Java-Themen 8
A System.in pipen Allgemeine Java-Themen 3
P System.getProperty zu Classloader Allgemeine Java-Themen 21
I Am System angemeldeten Benutzer abfragen Allgemeine Java-Themen 11
E System.out umleiten Allgemeine Java-Themen 2
S System Informationen auslesen. Allgemeine Java-Themen 3
N Thread und System.out.print() Allgemeine Java-Themen 2
K Kann man System.out in eine Datei speichern? ähnlich wie log Allgemeine Java-Themen 7
B Native DLL zweimal laden: System.load(sPath); Allgemeine Java-Themen 5
P System.getProperty("user.dir") Allgemeine Java-Themen 10
K Abfrage ob JRE oder JDK auf System installiert ist. Allgemeine Java-Themen 12
B serlvet system.out ausgabe Allgemeine Java-Themen 4
N Plugin-System: Klassen über String laden Allgemeine Java-Themen 3
O System.nanoTime() einheitlichen Wert auf mehreren Rechnern? Allgemeine Java-Themen 9
T System-Monitoring in Echtzeit Allgemeine Java-Themen 2
E System.out.println Allgemeine Java-Themen 5
G Umrechnen von grossen Zahlen ins Hex-System Allgemeine Java-Themen 3
G System.out.println(is.getClass().getName()); Allgemeine Java-Themen 15

Ähnliche Java Themen

Neue Themen


Oben