Vorhandenes das nicht existiert??

MiMa

Top Contributor
Hört sich widersprüchlich an, aber für mich sieht es so aus?!?
Nach langen suchen und probieren weis ich keinen Rat mehr und hoffe das es eine Lösung gibt das nicht vorhandene zu identifizieren.

Es ist mal wieder eine Audiodatei deren Metadaten ich einlese.
Ich habe alle Möglichkeiten abgefangen die existieren könnten (mit Werte, ohne Werte, mit teilweise Werte, usw.)

Das einlesen des Metatags Titelnummer kann einfach eine Zahl sein einstellig bis mehrstellig. (1,2,3,.....)
Es kann auch mit einem Trennzeichen (1/10)

MetadatenTitel.JPG

Im Code habe ich zum finden der Fehlerquelle folgenden Code hinzugefügt
Java:
if (titelnummer != null) {
            LOG.info("Die Titelnummer enthält einen Wert : " + titelnummer);
            LOG.info("Die länge der Titelnummer ist      : " + titelnummer.length());
    ...
Ausgegeben wird
Code:
2021-01-12 11:52:02 [main] INFO  - Die Titelnummer enthält einen Wert :
2021-01-12 11:52:02 [main] INFO  - Die länge der Titelnummer ist      : 0

Ein Blick in die Metadaten mit Directory Opus und MP3Tag kann ich erkennen das definitiv nichts sichtbares enthalten ist.
Ich habe auch schon geprüft ob ein Leerzeichen die Ursache sein kann? Ist es aber nicht!
Aber dennoch muss etwas da sein weil der Code != null erkennt und wenn ich von Hand die Metadatenfelder in Directoy Opus oder MP3 klicke und diese von Hand leer mache dann funktioniert mein Code wieder und das Ergebnis sind dann Standardwerte die ich definiert habe.

Das Problem wurde sichtbar als ich die Titelnummer in ein Integer mit Integer.parseInt umwandeln wollte.

Vielen Dank
Mi
 
K

kneitzel

Gast
Das ist dann der leere String. Du hast ja nicht nur null (was bedeutet, dass es keinen String gibt) sondern ein String kann auch leer sein.
 

MiMa

Top Contributor
Ich hatte auch mit folgenden Zeilen keine Logausgabe erreicht.

Java:
if (titelnummer == "" ){
                LOG.info("Ein Leerer String-Wert");
            }

Ich hatte ganz vergessen mit equals zu vergleichen.
Manchmal sieht man den Wald vor Bäumen nicht :)
Mit folgenden Zeilen habe ich die Ausgabe dann doch erreicht.
Java:
if (titelnummer.equals("")){
                LOG.info("Ein Leerer String-Wert");
            }

Danke.
Mi
 

MiMa

Top Contributor
Habe wieder mal so ein kurioses Problem mit einem int Wert bei Beats per Minute (bpm).
In MP3Tag sehe ich das der Wert 0 für bpm tatsächlich angezeigt wird.
Ich gehe dann davon aus das der int Wert dann auch 0 ist.

Auszug aus der Metadatenentnahme
Java:
mp3Tags.setBpm(id3v2Tag.getBPM());                  // Beats per Minute (bpm)
Mit dieser Codezeile wird der Wert aus den Metadaten an die Set-Methode gegeben.
Dann sollte auch der Wert 0 in der Set-Methode ankommen.
In der Regel werte ich dann dort aus was bei verschiedenen Werte passieren soll.
Java:
public void setBpm(int bpm) {
        System.out.println("BPM : " + bpm);
        if (bpm != 0) {
            LOG.info("BPM nicht ist 0");
            this.bpm = bpm;
        } else {
            LOG.info("BPM ist 0")
        }
        LOG.info("Speichert die BPM : " + this.bpm + "\n");
    }

Das Kuriose ist, das schon in der Methode bei denen die Metadaten abgefragt werden mit der einzelnen Zeile
Java:
mp3Tags.setBpm(id3v2Tag.getBPM());
schon einen Fehlermeldung ausgibt die da heißt
Code:
Exception in thread "main" java.lang.NumberFormatException: For input string: "0 Bpm"
    at java.base/jdk.internal.math.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2054)
    at java.base/jdk.internal.math.FloatingDecimal.parseFloat(FloatingDecimal.java:122)
    at java.base/java.lang.Float.parseFloat(Float.java:455)
    at com.mpatric.mp3agic.AbstractID3v2Tag.getBPM(AbstractID3v2Tag.java:600)
    at SoundStation.SoundParserMP3agic.sucheMP3Tags(SoundParserMP3agic.java:70)
    at SoundStation.SoundStation.main(SoundStation.java:106)
D:\Programmierung\Netbeans SoundStation\SoundStation\nbproject\build-impl.xml:1330: The following error occurred while executing this line:
D:\Programmierung\Netbeans SoundStation\SoundStation\nbproject\build-impl.xml:968: Java returned: 1
BUILD FAILED (total time: 0 seconds)

Was mich auch etwas irritiert, das "0 BMP" ausgegeben wird? Der Datentyp ist doch int!?!
Das bedeutet, das der Wert gar nicht erst an die Set-Methode kommt?
Ich habe auch geprüft, ob die Variablen auch alle den richtigen Typ haben und so ist es!

Wenn ich aber jetzt in der Methode wo die Metadaten entnommen werden folgenden Code eingebe
Java:
//            mp3Tags.setBpm(id3v2Tag.getBPM());                  // Beats per Minute (bpm)
            try {
                 if (id3v2Tag.getBPM() != 0) {
                LOG.info("BPM nicht ist 0");
                mp3Tags.setBpm(id3v2Tag.getBPM());
            }
            } catch (Exception e) {
                LOG.info("BPM ist 0");
                mp3Tags.setBpm(0);
            }
dann funktioniert der Code auch ohne Fehlermeldung?!??
Am liebten möchte ich das in der Set-Methode machen.

Danke
Mi
 
Zuletzt bearbeitet:

LimDul

Top Contributor
Der Code funktioniert nicht ohne Fehlermeldung. Du verschluckst nur die Fehlermeldung im Catch-Block, dir fliegt da eine Exception um die Ohren. Weil in den MP3-Tag was drin steht, was die Bibliothek, die du verwendest, nicht parsen kann und die keine saubere Fehlerbehandlung hat. Das heißt, du musst die Exception fangen (dann aber bitte die spezifische und nicht generell die generische Exception). Lösen kannst du das, wenn du in der Set-Methode machen willst, in dem du da nicht den Wert rein gibts sondern eine Methodenreferenz:

Java:
public void setBpm(Supplier<Integer> bpmSupplier) {
         try {
         int bpm = bpmSupplier.get();
        System.out.println("BPM : " + bpm);
        if (bpm != 0) {
            LOG.info("BPM nicht ist 0");
            this.bpm = bpm;
        } else {
            LOG.info("BPM ist 0")
        }
    } catch (NumberFormatException e) {
      LOG.info("BPM ist ungültig, setze auf 0")
      this.bpm = 0;
    }
   LOG.info("Speichert die BPM : " + this.bpm + "\n");  
}

Der Aufruf erfolgt dann mittels:
Java:
mp3Tags.setBpm(id3v2Tag::getBPM);                  // Beats per Minute (bpm)
 

MiMa

Top Contributor
Die Methode in der die Metadaten gelesen werden ruft zwar die Set-Methode auf aber es wird kein Wert übergeben.
Den Wert holt sich die Set Methode dann über den Supplier?
Habe ich das so richtig verstanden?
 

MiMa

Top Contributor
Vielen Dank, wieder was neues gelernt :)
Im Grunde wollte ich zum extrahiere Apache Tika verwenden, aber mit dieser Bibliothek kann ich ein paar Werte nicht ermitteln und MP3agic finde ich eigentlich ganz gut, bis auf einige wenige Ausnahmen. Schade nur das es scheinbar nicht weiter entwickelt wird.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Auf vorhandenes Window zeichnen? Allgemeine Java-Themen 2
Zrebna Wieso sollte man Null-Prüfungen nicht mit Optional-Objekten nutzen? Allgemeine Java-Themen 13
kodela Textfeld nicht rechteckig Allgemeine Java-Themen 10
G Doppelklick auf Javaprogramm klapt nicht Allgemeine Java-Themen 1
W Timer terminiert nicht Allgemeine Java-Themen 5
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
W Überflüssige Deklaration vermeiden...war da nicht mal was? Allgemeine Java-Themen 3
N lwjgl kann textureSampler nicht finden Allgemeine Java-Themen 4
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
T .Jar kann man nicht ausführen Allgemeine Java-Themen 18
P JDK nicht installiert in Net Object Fusion Allgemeine Java-Themen 7
D Image bewegt sich nicht nach Klicken auf Button Allgemeine Java-Themen 15
N Regex schlägt nicht an Allgemeine Java-Themen 10
Y Wieso krieg ich die Unit Tests nicht hin Allgemeine Java-Themen 55
D Erste Schritte Mp3 Datei kann nicht von der Festplatte geöffnet werden - mit ChatGPT erstellt Allgemeine Java-Themen 7
G Popup wird nicht sichtbar Allgemeine Java-Themen 9
8u3631984 Funktions Parameter mit Lombok "NonNull" annotieren wird in Jacococ Testcoverage nicht herausgefiltert Allgemeine Java-Themen 3
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
M Apache Proxy Weiterleitung auf Tomcat funktioniert nicht wie gewünscht Allgemeine Java-Themen 1
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
OnDemand ApacheCommon FTP Client zuckt nicht Allgemeine Java-Themen 3
T JavaPoet - (noch) nicht existente Typen Allgemeine Java-Themen 2
E Es ist nicht möglich, eine Batch-Anweisung auszuführen. Allgemeine Java-Themen 9
C Was passt hier nicht bei der Calendar-Class Allgemeine Java-Themen 2
T Testing JUnit5: try ... catch arbeitet nicht sauber Allgemeine Java-Themen 6
W While Schleife funktioniert nicht ganz Allgemeine Java-Themen 4
OnDemand MemoryLeak nicht zu finden Allgemeine Java-Themen 26
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
H do-while Schleife funktioniert nicht wie ich es möchte Allgemeine Java-Themen 7
ERlK JDA Code funktioniert nicht? Allgemeine Java-Themen 4
OnDemand Ram Freigabe erfolgt nicht nach Prozessende Allgemeine Java-Themen 18
OnDemand XML desializing Attribute bringt nicht erwartetes Ergebnis Allgemeine Java-Themen 16
T ImageIcon wird nicht angezeigt Allgemeine Java-Themen 6
N JAVA-Code mit Grafikfenster zeichnet in Windows, aber nicht Mac. Allgemeine Java-Themen 4
stormyark TikTakToe funktioniert nicht Allgemeine Java-Themen 10
N Warum wird die For Schleife nicht betreten Allgemeine Java-Themen 4
Tiago1234 Hauptklasse konnte nicht gefunden oder geladen werden Allgemeine Java-Themen 38
T Remove bei ArrayList funktioniert nicht Allgemeine Java-Themen 2
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
I "Neues" Lizenzmodell Oracle - JRE nicht mehr zur Redistribution freigegeben? Allgemeine Java-Themen 16
J c Programm läuft nicht in compilierter Version des Java Projektes Allgemeine Java-Themen 7
A code wird nicht ausgeführt Allgemeine Java-Themen 3
Blender3D Alte Beiträge nicht mehr vorhanden Allgemeine Java-Themen 6
M Warum hat Java dieses und jenes nicht... Allgemeine Java-Themen 8
W Bilder werden in App mit Jar-Datei nicht angezeigt Allgemeine Java-Themen 15
Micha43 Applet *.jar läuft nicht auf dem Mac Allgemeine Java-Themen 8
M Warum bekommen ich den Result nicht ? Allgemeine Java-Themen 17
Kiki01 Häufigster Buchstabe lässt sich nicht ermitteln Allgemeine Java-Themen 30
OnDemand RegEx /compilebekomme nicht die erwarteten Werte Allgemeine Java-Themen 9
HerrBolte Seltsamer Fehler nur in der Windows- und nicht in der Java-Console O_O Allgemeine Java-Themen 16
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
N nicht einsehbarer Fehler im code, kann nicht mehr übersetzten Allgemeine Java-Themen 51
P Karate API Test läuft nicht durch . initializationError Allgemeine Java-Themen 21
N nicht static und auch nicht new Allgemeine Java-Themen 3
Z macOS java konnte nicht entfernt werden xpc verbindungsfehler Allgemeine Java-Themen 4
T Schaltfläche wird nicht gefunden Allgemeine Java-Themen 4
boschl2000 Springerproblem-Implementierung funktioniert nicht richtig Allgemeine Java-Themen 1
F Getter Methode aufrufen funktioniert nicht Allgemeine Java-Themen 1
N Gierigen Regex in nicht-gierigen umwandeln Allgemeine Java-Themen 4
N Regulärer Ausdruck funktioniert nicht Allgemeine Java-Themen 6
AleXusher Hauptklasse startlösung konnte nicht gefunden oder geladen werden Allgemeine Java-Themen 1
G @PostConstruct Annotation nicht mehr gültig ? Allgemeine Java-Themen 7
L Objekte in Set nicht gefunden Allgemeine Java-Themen 13
T Projekt baut nicht mehr/lässt sich nicht mehr ausführen Allgemeine Java-Themen 6
izoards log4j2 will nicht.... Allgemeine Java-Themen 15
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
1Raini Java if-Abfrage funktioniert nicht! Allgemeine Java-Themen 3
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
I serialVersionUID - explizit vergeben oder nicht? Allgemeine Java-Themen 6
LimDul Hä? Lambda-Ausdruck geht, Methoden-Referenz nicht Allgemeine Java-Themen 8
O Jar lässt sich auf bestimmten Pc nicht starten Allgemeine Java-Themen 18
T Fremde Typen mockt man nicht? Allgemeine Java-Themen 3
Killunox MaxHeap Zuweisung unter Linux funktioniert nicht Allgemeine Java-Themen 1
LimDul Direktes return eines Array geht nicht Allgemeine Java-Themen 20
B neuroph hält beim XOR lernen nicht an Allgemeine Java-Themen 13
kodela JDialog zeigt Text nicht an Allgemeine Java-Themen 5
Dann07 Java-Programm findet DLLs nicht! Allgemeine Java-Themen 20
D Twitch API mit HttpURLConnection läuft nicht? Allgemeine Java-Themen 0
M Test geht auf Travis und mit Github Action schief aber nicht lokal Allgemeine Java-Themen 3
R Threads Clip loop loopt nicht Allgemeine Java-Themen 2
Dann07 MP3 Datei abspielen funktioniert nicht Allgemeine Java-Themen 6
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
OnDemand JMS Messages nicht abgeholt Allgemeine Java-Themen 0
O Aus JAR-Datei erstellte EXE-Datei funktioniert nicht Allgemeine Java-Themen 10
A Mp3 Player funktioniert nicht Allgemeine Java-Themen 0
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
M Console geht nicht auf (Windows 10) Allgemeine Java-Themen 3
J Hilfe, Jar Datei kann nicht ausgeführt werden Allgemeine Java-Themen 2
W Enumeration ein Array/List als Eigenschaft mitgeben - warum geht das nicht? Allgemeine Java-Themen 0
W Javac nicht bei Installation installiert Allgemeine Java-Themen 9
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Java.exe exestiert, aber irgendwie auch nicht Allgemeine Java-Themen 11
D ArrayListe delete Methode klappt nicht Allgemeine Java-Themen 12
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
X JNA funktioniert nicht mehr Allgemeine Java-Themen 4
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
Drachenbauer Division mit Int funktioniert nicht Allgemeine Java-Themen 3
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben