Geht dieser Code noch einfacher (try catch finally)

H

hüteüberhüte

Gast
Java:
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.URL;
import java.nio.ByteBuffer;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.GregorianCalendar;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Main {

    private static final Pattern[] pat = {
        Pattern.compile("<img src=\"(http://www.example.com/1)\" class=\"[^\"]+\" alt=\"[^\"]+\" />"),
        Pattern.compile("<img src=\"(http://www.example.com/2)\" class=\"[^\"]+\" alt=\"[^\"]+\" />"),
        Pattern.compile("<img src=\"(http://www.example.com/3)\" class=\"[^\"]+\" alt=\"[^\"]+\" />")};
    private static final int[] indexes = new int[pat.length];
    private static final SimpleDateFormat sdf =
            (SimpleDateFormat) DateFormat.getDateTimeInstance(DateFormat.SHORT, DateFormat.MEDIUM);
    private static final String formatStr = "%d_%04d.jpg";
    private static final ByteBuffer byteBuffer = ByteBuffer.allocate(262144);

    public static void main(String[] args) throws InterruptedException {
        GregorianCalendar gc_to = new GregorianCalendar(
                Integer.parseInt(args[0]),
                Integer.parseInt(args[1]) - 1,
                Integer.parseInt(args[2]),
                Integer.parseInt(args[3]),
                Integer.parseInt(args[4]));
        System.out.println("gc_to = " + sdf.format(gc_to.getTime()));
        while (System.currentTimeMillis() <= gc_to.getTimeInMillis()) {
            BufferedReader br = null;
            try {
                br = new BufferedReader(new InputStreamReader(new URL("http://www.example.com/").openStream()));
                String s;
                while ((s = br.readLine()) != null) {
                    for (int i = 0; i < pat.length; i++) {
                        Matcher m = pat[i].matcher(s);
                        if (m.find()) {
                            System.out.println(sdf.format(new Date()) + " Speichere " + m.group(1) + " ...");
                            byteBuffer.clear();
                            BufferedInputStream bis = null;
                            try {
                                bis = new BufferedInputStream(new URL(m.group(1)).openStream());
                                int b;
                                while ((b = bis.read()) != -1) {
                                    byteBuffer.put((byte) b);
                                }
                            } finally {
                                if (bis != null) {
                                    try {
                                        bis.close();
                                    } catch (IOException ioe) {
                                        ioe.printStackTrace();
                                    }
                                }
                            }
                            if (new File(String.format(formatStr, i + 1, indexes[i] - 1)).length() == byteBuffer.position()) {
                                break;
                            }
                            BufferedOutputStream bos = null;
                            try {
                                bos = new BufferedOutputStream(new FileOutputStream(String.format(formatStr, i + 1, indexes[i]++)));
                                for (int j = 0; j < byteBuffer.position(); j++) {
                                    bos.write(byteBuffer.get(j));
                                }
                                bos.close();
                            } finally {
                                if (bos != null) {
                                    try {
                                        bos.close();
                                    } catch (IOException ioe) {
                                        ioe.printStackTrace();
                                    }
                                }
                            }
                            break;
                        } // if m find
                    } // for pat
                } // while br readLine
            } catch (IOException ioe) {
                ioe.printStackTrace();
            } finally {
                if (br != null) {
                    try {
                        br.close();
                    } catch (IOException ioe) {
                        ioe.printStackTrace();
                    }
                }
            } // try catch finally
            Thread.sleep(75L * 1000L);
        } // while millis
    } // main
} // Main

Er funktioniert, aber das Problem ist, ich steige selbst langsam nicht mehr durch. Kann man die Anzahl der try s... verringern, aber dass die Semantik erhalten bleibt?

Danke fürs Durchlesen...

Grüße!
 
G

Gast2

Gast
Mit Java 7 und try-with-ressources oder du schreibst dir halt ne kleine Hilfsmethode:

Java:
public void close (Closeable c) {
  if (c != null) {
    try {
      c.close();
    } catch (IOException ioe) {
      ioe.printStacktrace();
    }
  }
}
Die kannst du dann aufrufen und sparst dir die drei try-catch Blöcke.
 

Marco13

Top Contributor
Sieht halt auch insgesamt sehr unübersichtlich aus - Parsen, Matchen, Regex, Dateiverarbeitung... alles in der main zusammengewurstet... Was wird da gemacht? Ist das (wieder einmal) der (zum Scheiter verurteilte) Versuch, HTML-Inhalte durch RegEx abzugrasen? Falls ja: Vielleicht mal einen passenden Parser verwenden. Da war kürzlich auch http://www.java-forum.org/allgemeine-java-themen/142697-html-parsing-errors.html#post949727 , was in eine ähnliche Richtung gehen könnte...
 
B

bygones

Gast
wie gesagt, java7 ist schonmal ein schritt, ansonten code duplikationen auslagern, abstraktionen einfuehren, bessere Methodensplitten und und und
 
H

hüteüberhüte

Gast
@Marco: Das parsen funktioniert hervorragend. Close habe ich ausgelagert. Für das andere muss ich mir viell. noch etwas überlegen, wie man etwas in Methoden auslagern könnte. Das Ding ist, das zeilenweise eingelesen werden soll und wenn ein bestimmter Ausdruck zutrifft, wieder etwas geladen werden soll
 

Ullenboom

Bekanntes Mitglied
Das

Java:
GregorianCalendar gc_to = new GregorianCalendar(
                Integer.parseInt(args[0]),
                Integer.parseInt(args[1]) - 1,
                Integer.parseInt(args[2]),
                Integer.parseInt(args[3]),
                Integer.parseInt(args[4]));

knallt doch sofort, wenn auf der Kommandozeile keine Zahlen übergeben werden. Das wird doch gar nicht behandelt und sieht als RuntimeException nicht gut aus.
 

Marco13

Top Contributor
@Marco: Das parsen funktioniert hervorragend.

Wenn jemand den Quelltext ändert zu
<img src=... CLASS=... alt=... />
(Groß/Kleinschreibung) oder gar zu
<img src=... alt=... class=... />
(Attributreihenfolge vertauscht)
haut's ihn komplett raus. Vielleicht ist dir das egal, wenn es ein "one-shot-Utility" ist (ja, sowas macht jeder mal :oops: ) aber allgemein gilt: Man parst HTML einfach nicht mit RegEx :noe:
 
H

hüteüberhüte

Gast
Das mit gc_to ist schon ok, und ist auch gewollt, dass das Programm dann gar nicht erst startet. Es ist nur für mich gedacht, und die "Ziel"-Seite ändert sich so schnell net.
Regex ist deshalb die beste Wahl - selbst mit einem HTML-Parser müsste auf veränderte Strukturen reagiert werden.
Danke aber für Vroschläge!
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Geht dieser Code noch einfacher? Java Basics - Anfänger-Themen 16
V Wie und wieso geht dieser Methodenaufruf? Java Basics - Anfänger-Themen 2
D MacOS: PDF erstellen geht nicht Java Basics - Anfänger-Themen 1
P Netbeans installation geht nicht Java Basics - Anfänger-Themen 26
Ostkreuz wie geht der catch? Java Basics - Anfänger-Themen 3
A Methoden Guten Tag , ich wollte so machen dass wenn meine frog an eine fly/bee geht dann an meine Tafel geht der zahl +1 hoch. Java Basics - Anfänger-Themen 2
S IntelliJ geht alle Klassen durch Java Basics - Anfänger-Themen 9
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
Say Stelle in Code herausfinden, wie geht man vor? Java Basics - Anfänger-Themen 12
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
P Installation JRE 8u321 startet, geht aber nicht weiter Java Basics - Anfänger-Themen 1
E Rekursiv Objekte erzeugen - geht das? Java Basics - Anfänger-Themen 2
E Pervasive PSQL insert funktion geht nicht Java Basics - Anfänger-Themen 9
U Warum kann ich die Methode in der ENUM Klasse nicht aufrufen? Und warum geht die Switch nicht? Java Basics - Anfänger-Themen 8
H Wie geht eigentlich Objektorientierung? Java Basics - Anfänger-Themen 14
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
melisax Lower & Uppercase Beispielprogramm geht nicht Java Basics - Anfänger-Themen 3
MarcKKKK123 Wie geht das? Java Basics - Anfänger-Themen 1
B Static Attribute in einer Klasse, wie geht das? :O Java Basics - Anfänger-Themen 19
N methodenaufruf for each geht nicht Java Basics - Anfänger-Themen 2
O Methode in while-Schleife aufrufen geht nur beim ersten Mal Java Basics - Anfänger-Themen 2
W App geht live und dann? Java Basics - Anfänger-Themen 9
P Geht es vielleicht viel kürzer? Java Basics - Anfänger-Themen 7
S While-Schleife geht in Endlosschleife über, warum? Java Basics - Anfänger-Themen 6
B Interface List - Objekt übergeben? Einzelnes Objekt geht, aber Liste nicht? Java Basics - Anfänger-Themen 4
K Erste Schritte Programm geht aus Schleife, warum? Java Basics - Anfänger-Themen 2
S Geht das bei Java ? Java Basics - Anfänger-Themen 11
L Wie geht man bei mehreren Action Klassen vor? Java Basics - Anfänger-Themen 0
C unverständlicher Code Attribute ohne Datentyp, wie geht das? Java Basics - Anfänger-Themen 8
B OCR - Rechnungserkennung, wie geht das genau? Java Basics - Anfänger-Themen 59
CptK Klassen KeyListner geht nicht Java Basics - Anfänger-Themen 7
L Klassen Objekt aus einer Warteschlange in eine andere übergeben, geht nicht? Java Basics - Anfänger-Themen 6
K Armstrong Programm geht nur bis 1000, aber nicht weiter Java Basics - Anfänger-Themen 2
M Nim-Spiel geht in den negativen Bereich Java Basics - Anfänger-Themen 1
amazinglife77 Input/Output Lesen/Schreiben Properties: in eclipse geht, als JAR nicht Java Basics - Anfänger-Themen 4
V Erste Schritte Warum geht meine continue Anweisung nicht? Java Basics - Anfänger-Themen 8
MR._FIRE_Flower String.split("(") geht nicht Java Basics - Anfänger-Themen 4
M Restbuchwert Berechnung geht nicht Java Basics - Anfänger-Themen 45
K Klassen Nachträglich ein Objekt einem anderen zuweisen, geht das? Java Basics - Anfänger-Themen 2
S int addieren geht nicht Java Basics - Anfänger-Themen 13
L system.print.out geht nicht Java Basics - Anfänger-Themen 11
M Referenz geht bei Zwischenspeichern verloren (ArrayList) Java Basics - Anfänger-Themen 4
S Komma geht beim Schreiben ins csv verloren. Java Basics - Anfänger-Themen 6
M Arrays einspeichern geht nicht Java Basics - Anfänger-Themen 21
J BlueJ und import-Anweisungen, wie geht das? Java Basics - Anfänger-Themen 4
J Geht mit Java überhaupt was? Java Basics - Anfänger-Themen 13
J Debuggen - wie geht das? Java Basics - Anfänger-Themen 6
I erstelle Vorschaubild mit der lib PDF-Renderer und möchte danach Dateiname ändern -> geht aber nicht Java Basics - Anfänger-Themen 0
J Ausführen geht nicht Java Basics - Anfänger-Themen 19
G System.out.printf geht nicht Java Basics - Anfänger-Themen 6
E Erste Schritte [Noob] Warum geht meine For-Schleife nicht? Java Basics - Anfänger-Themen 2
I Java Code so gut es geht Kommentieren Java Basics - Anfänger-Themen 4
S Button "Berechnen" geht nicht Java Basics - Anfänger-Themen 3
B Compiler-Fehler Ein Java-Eclipse-Anfänger geht auf Reisen... Java Basics - Anfänger-Themen 10
K JUnit: Objekte von eigenen Klassen vergleichen...geht nicht Java Basics - Anfänger-Themen 5
T fianl array geht nicht... Java Basics - Anfänger-Themen 2
O if and else geht nur manchmal Java Basics - Anfänger-Themen 17
B Nichts geht mehr Java Basics - Anfänger-Themen 10
D Java geht auf windows 64 bit nicht. Java Basics - Anfänger-Themen 5
V Einfacher vergleich von Arrays geht schief Java Basics - Anfänger-Themen 2
T sample.war geht nicht... Java Basics - Anfänger-Themen 1
Thallius Klassen aus Classname programmatisch erzeugen. Wie geht das in java? Java Basics - Anfänger-Themen 5
C Datentypumwandlung geht nicht Java Basics - Anfänger-Themen 5
U kompilieren geht nicht wg. Formatierung wahrscheinlich Java Basics - Anfänger-Themen 7
G While schleife mit 2 Bedingungen geht nicht! Java Basics - Anfänger-Themen 15
S Methoden Rückgabewert einer Methode als Parameter an eine andere Methode übergeben, geht das? Java Basics - Anfänger-Themen 5
L Das erste Mal GridBagLayout - wie geht das? Java Basics - Anfänger-Themen 5
O Jar Datei erstellen geht nicht. Java Basics - Anfänger-Themen 4
O (.+?) --> $1 geht nicht Java Basics - Anfänger-Themen 5
V relativer Pfad geht nicht, absolut schon? Java Basics - Anfänger-Themen 3
R Java JDK/ Kompiler geht nicht Java Basics - Anfänger-Themen 4
J Warum geht int und String nicht? Java Basics - Anfänger-Themen 18
J repaint() geht gar nicht; GUI aktualisieren Java Basics - Anfänger-Themen 10
N ArrayList geht nicht Java Basics - Anfänger-Themen 8
B Erste Schritte Listing aus Buch - wie geht das? Java Basics - Anfänger-Themen 6
K Datentypen Kurzform Addition geht, Langform scheitert am Typen Java Basics - Anfänger-Themen 6
R Einfacher Timer geht nicht Java Basics - Anfänger-Themen 7
J Anzeige erneuern, wie geht das? Java Basics - Anfänger-Themen 6
D Compiler-Fehler ANT-Script geht nicht Java Basics - Anfänger-Themen 6
A Android Datenbank gaaanz einfaches Insert geht nicht - warum? Java Basics - Anfänger-Themen 4
N JAVA Installation - Umgebungsvariable geht nicht. Java Basics - Anfänger-Themen 3
K Aus JFrame-Fenster SuM-Fenster öffnen geht nicht! Java Basics - Anfänger-Themen 8
L Jarfiles packen, wie geht's genau? Java Basics - Anfänger-Themen 12
K Erste Schritte Progressbar geht nicht Java Basics - Anfänger-Themen 5
H Ein alternativer Konstruktor geht nicht Java Basics - Anfänger-Themen 3
B Std-Serialisierung - Speichern/Laden geht nur auf einem Rechner Java Basics - Anfänger-Themen 17
F Geht in alle Case rein, warum?? Java Basics - Anfänger-Themen 12
El_Lobo Methoden Zu viele Getter- und Settermethoden - geht das einfacher? Java Basics - Anfänger-Themen 3
P quickSort eines Objekt-Arrays geht nicht! Java Basics - Anfänger-Themen 11
M if then else geht nicht Java Basics - Anfänger-Themen 10
N Methoden mehrere replace hintereinander geht nicht ? Java Basics - Anfänger-Themen 2
Maxim6394 KeyListener geht nicht Java Basics - Anfänger-Themen 15
C Erste Schritte switch Anweisung geht nicht Java Basics - Anfänger-Themen 3
N geht oder geht nicht? Java Basics - Anfänger-Themen 24
E bo wie geht das denn? Java Basics - Anfänger-Themen 8
Z Anfügen an Arraylist geht nicht Java Basics - Anfänger-Themen 3
M Unterverzeichnisse löschen geht nicht. Java Basics - Anfänger-Themen 3
T Methoden Array kopieren: Wie geht das? Java Basics - Anfänger-Themen 20
M If Abfrage geht nicht Java Basics - Anfänger-Themen 2
0 file.delete() geht nicht Java Basics - Anfänger-Themen 23

Ähnliche Java Themen

Neue Themen


Oben