Accéder au contenu principal

Utilisation de la librairie Java ID3 Tag

Il s'agit d'une librairie Java qui permet, entre autres, d'extraire le contenu des tags ID3Vx depuis un fichier mp3. Cette librairie est disponible sur sourceforge.
Pour extraire les paroles (Lyrics) depuis une page JSP par exemple, il faut utiliser un code semblable à ce qui suit:
<%@page import="org.farng.mp3.id3.*"%>
String lyrics="test";
RandomAccessFile fic;
ID3v2_3 tagz = new ID3v2_3();
try {
fic = new RandomAccessFile("<... CHEMIN DU FICHER MP3 ...>" ,"r");
tagz = new ID3v2_3(fic);
} catch (IOException io) {
System.out.println("erreur : le fichier n'est pas valide");
}catch (TagException tag) {
System.out.println("erreur : le format du fichier n'est pas valide");
}

// lecture des paroles
System.out.println("Extraction des Lyrics");
lyrics=tagz.getSongLyric();


Cela marchera pour les fichiers qui contiennent un tag Lyric de type ID3 V2 (Unsychronised lyrics/text transcription) avec une valeur de l'attribut language='eng'. Ne pas confondre ce tag avec celui, plus ancien, qui enregistre les paroles à la fin du fichier.
Pour les paroles qui ont été ajoutées avec un outil paramétré en français (iTunes, Explorateur Windows etc.), l'appel ne renverra aucun texte.
Il est necessaire de patcher une classe du package. Cette classe est : ID3v2_3.

Manipulations:

Récuperer le source de la librairie
Extraire le contenu du fichier jid3lib-0.5.4.jar
jar -xvf jid3lib-0.5.4.jar
Editer le fichier ID3v2_3.java (dans le repertoire src/org/farng/mp3/id3
Aprés le motif:

if (text == "") {
frame = getFrame("USLT" + ((char) 0) + "eng" + ((char) 0) + "");
if (frame != null) {
FrameBodyUSLT body = (FrameBodyUSLT) frame.getBody();
text = body.getLyric();
}
}


il suffit d'ajouter celui-ci:

if (text == "") {
frame = getFrame("USLT" + ((char) 0) + "fre" + ((char) 0) + "");
if (frame != null) {
FrameBodyUSLT body = (FrameBodyUSLT) frame.getBody();
text = body.getLyric();
}
}


Puis refaire une librairie avec la commande jar.
jar -cvf jid3lib-0.5.4.jar *
Vérifier la présence de deux repertoires: org et META-INF dans le fichier final.
La doc qui est fourni avec la librairie est très pédagogique. Le formalisme ID3 dans sa version V2 tranforme un fichier MP3 en véritable mini base de données !

Commentaires

Posts les plus consultés de ce blog

Auschwitz

 Quelques livres à propos des camps d'Auschwitz La mort est mon métier (Robert Merle) - 1952 Roman avec Rudolf Hoess (responsable camps d'Auschwitz) comme personnage principal Si c'est un homme (Primo Levi) - 1947 Témoignage de Primo Levi sur sa captivité à Auschwitz Les médecins d'Auschwitz (Bruno Halioua) - 2022 Etude sur l'organisation des services de médecine à Auschwitz Je me suis évadé d'Auschwitz (Rudolf Vrba) - 2004 Récit d'un captif qui a réussi à s'échapper d'Auschwitz Shoah  (Claude Lanzmann) - 1985 Dialogues du film "Shoah" Sonderkommando : Dans l'enfer des chambres à gaz  (Shlomo Venezia ) Entretien avec un ancien prisonnier qui a tenu le rôle de sonderkommando (manipulation des corps dans les chambres à gaz) Auschwitz I Birkenau Birkenau

Oracle Documents Cloud Service - Using Upload File REST API

If the Upload File sample given in ODCS documentation is used "as is", we get a http 400 error. The syntax is strict and every blank line must be empty (no space character for instance). If we cust and paste the sample, there are residual space characters which must be removed. So, use this pattern instead: -----1234567890 Content-Disposition: form-data; name="jsonInputParameters" { "parentID": " " } -----1234567890 Content-Disposition: form-data; name="primaryFile"; filename="example.txt" Content-Type: text/plain Hello World! -----1234567890-- instead the original one: -----1234567890 Content-Disposition: form-data; name="jsonInputParameters" { "parentID":"FB4CD874EF94CD2CC1B60B72T0000000000100000001" } -----1234567890 Content-Disposition: form-data; name="primaryFile"; filename="example.txt" Content-Type: text/plain -----1234567890-- Tests can be...

Oracle Sites Cloud Service - Apps

It's possible to add kinds of widgets (named APPS) inside any page of a site built with Oracle Sites Cloud Service (SCS). Any app is materialized by two URL: a Renderer Url which will render any HTML fragment inside an iframe tag at runtime a settings url which will be rendrered at design time in the settings menu. all URLs must be called through https (meaning that the called server has to be ssl enabled) In the following samples, we integrate: a dummy app (a simple html page produced with node.js) which demonstrates the parameteres caried by the Sites Cloud engine when calling the backend server,  a regular Apex report or form,  a custom report which calls a rest api generated by Apex /ORDS Sample node.js server.js below is a sample of parameter values get from a dummy node.js server Main call id=26e45e21-dbb6-4877-9886-482b37213d2f instance=eyJpbnN0YW5jZWlkIjoiQTI0NUNFNUNFNjA5MjE1REZBRTA2RTQyRjExOThBNThFNzc4RDc5NzFDMkIiLCJzaWduZGF0ZSI6IjE0NTAxMDg1M...