|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Jun 2005
Città: CH
Messaggi: 1058
|
[JAVA] Leggere file XML help
ho creato questo file xml:
Codice:
<?xml version="1.0"?> <libri> <libro> <autore>pippo</autore> <titolo>primo titolo</titolo> <costo>11</costo> </libro> <libro> <autore>sandro</autore> <titolo>secondo titolo</titolo> <costo>34</costo> </libro> </libri> |
![]() |
![]() |
![]() |
#2 | |
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Quote:
Se non hai mai usato questi parser, ti conviene studiare e valutare bene i vari tipi per stabilire cosa è meglio usare. Inizia da: http://en.wikipedia.org/wiki/Java_AP...XML_Processing
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
|
SAX è un parser procedurale, si può usare per file molto grandi (genere un gigabyte) ma penso che DOM sia più comprensibile in quanto dichiara l'esistenza di nodi, elementi e attributi che hanno un'immediata corrispondenza con la struttura di un documento XML.
Quanto alla differenza C#, Java, le due lingue sono praticamente identiche, probabilmente è una questione di librerie. Potresti provare a guardare se la fondazione Apache ha le librerie XML DOM per C#: sono le stesse usate da Java. Comunque, il grosso della lettura di un documento XML in Java con DOM sta nell'ottenere l'oggetto Document. Bisogna passare per un po' di intermediari. Supponiamo che il file si chiami "documento.xml". La lettura di questo documento si farebbe con: Codice:
DocumentBuilderFactory factory; DocumentBuilder builder; Document document; try { factory = DocumentBuilderFactory.newInstance(); builder = factory.newDocumentBuilder(); document = builder.parse(new java.io.File("documento.xml")); gestioneDocumento(document); //un metodo definito a parte } catch(Exception ex) { ex.printStackTrace(); //varie } Ad esempio, per quel documento, il nodo "libri", radice del documento, è: Element radice = document.getDocumentElement(); Puoi recuperare direttamente i nodi "libro" con il metodo getElementsByTagName(string) di Document: NodeList elencoLibri = document.getElementsByTagName("libro"); Il NodeList è una lista che ha nodeList.getLength() elementi ognuno dei quali accessibile con lista.item(indice). Per prelevare il testo contenuto in un nodo puoi usare il metodo getTextContent(). Ad esempio per il nodo: <autore>Pippo</autore> il metodo getTextContent restituisce Pippo. I nodi come autore, costo, libro, libri, titolo, sono degli elementi. E' utile saperlo perche gli elementi (Element) hanno dei metodi in più rispetto ai nodi (Node), in particolare ti permettono di ottenere una lista di tutti i figli di nome N. Scrivo un esempio di lettura del documento xml che hai incollato. Codice:
import org.w3c.dom.*; import javax.xml.parsers.*; public class Main { public static void main(String[] args) { DocumentBuilderFactory factory; DocumentBuilder parser; Document document; try { factory = DocumentBuilderFactory.newInstance(); parser = factory.newDocumentBuilder(); document = parser.parse(new java.io.File("documento.xml")); handleDocument(document); } catch(Exception ex) { System.out.println("Errore."); ex.printStackTrace(); } } private static void handleDocument(Document document) { /* Tutti i nodi contenuti in document che si chiamano "libro" */ NodeList libri = document.getElementsByTagName("libro"); for(int i = 0; i < libri.getLength(); i++) { Element libro = (Element)libri.item(i); String autore = libro.getElementsByTagName("autore").item(0).getTextContent(); String titolo = libro.getElementsByTagName("titolo").item(0).getTextContent(); String prezzo = libro.getElementsByTagName("costo").item(0).getTextContent(); System.out.println("Autore: " + autore); System.out.println("Titolo: " + titolo); System.out.println("Prezzo: " + prezzo); } } } libro.getElementsByTagName(X).item(0).getTextContent() sono la concatenazione di: NodeList figli = libro.getElementsByTagName(X); Node x = figli.item(0); String testo = x.getTextContent(); Cioè dato il nodo libro, che sarebbe: Codice:
<libro> <autore>pippo</autore> <titolo>primo titolo</titolo> <costo>11</costo> </libro> libro.getChildNodes().item(0); non corrisponderebbe ad ottenere il nodo "autore" ma uno strambo nodo che c'è ma non si vede. Cercando i figli per nome sei certo di andare a pescare dove dovresti.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me! |
![]() |
![]() |
![]() |
#4 |
Senior Member
Iscritto dal: Jun 2005
Città: CH
Messaggi: 1058
|
vi ringrazio
![]() ![]() |
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Jun 2005
Città: CH
Messaggi: 1058
|
Errori:
Codice:
init: deps-jar: Compiling 1 source file to C:\Documents and Settings\edpsam\Desktop\Progetti JAVA\Gestione XML\leggereXML\build\classes compile: Errore. java.io.FileNotFoundException: C:\Documents and Settings\edpsam\Desktop\Progetti JAVA\Gestione XML\leggereXML\dati.xml (The system cannot find the file specified) at java.io.FileInputStream.open(Native Method) at java.io.FileInputStream.<init>(FileInputStream.java:106) at java.io.FileInputStream.<init>(FileInputStream.java:66) at sun.net.www.protocol.file.FileURLConnection.connect(FileURLConnection.java:70) at sun.net.www.protocol.file.FileURLConnection.getInputStream(FileURLConnection.java:161) at com.sun.org.apache.xerces.internal.impl.XMLEntityManager.setupCurrentEntity(XMLEntityManager.java:973) at com.sun.org.apache.xerces.internal.impl.XMLVersionDetector.determineDocVersion(XMLVersionDetector.java:184) at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:798) at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:764) at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:148) at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:250) at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:292) at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:172) at Main.Main.main(Main.java:28) debug: BUILD SUCCESSFUL (total time: 1 second) Codice: Codice:
package Main; /** * * @author edpsam */ import org.w3c.dom.*; import javax.xml.parsers.*; public class Main { public static void main(String[] args) { DocumentBuilderFactory factory; DocumentBuilder parser; Document document; try { factory = DocumentBuilderFactory.newInstance(); parser = factory.newDocumentBuilder(); document = parser.parse(new java.io.File("dati.xml")); handleDocument(document); } catch(Exception ex) { System.out.println("Errore."); ex.printStackTrace(); } } private static void handleDocument(Document document) { /* Tutti i nodi contenuti in document che si chiamano "libro" */ NodeList libri = document.getElementsByTagName("libro"); for(int i = 0; i < libri.getLength(); i++) { Element libro = (Element)libri.item(i); String autore = libro.getElementsByTagName("autore").item(0).getTextContent(); String titolo = libro.getElementsByTagName("titolo").item(0).getTextContent(); String prezzo = libro.getElementsByTagName("costo").item(0).getTextContent(); System.out.println("Autore: " + autore); System.out.println("Titolo: " + titolo); System.out.println("Prezzo: " + prezzo); } } } xche? |
![]() |
![]() |
![]() |
#6 |
Senior Member
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
|
FileNotFoundException
Non trova il file. Dove si trova? new java.io.File("dati.xml") "dati.xml" è un percorso relativo. Per trovare un file ci vuole un percorso assoluto. Se specifichi un percorso relativo esso viene trasformato in un percorso assoluto usando come base il percorso della cartella di lavoro del programma. La cartella di lavoro del programma è una variabile associata al processo. Può essere maneggiata e rimaneggiata ma, di solito, è la stessa del processo "padre". Senza star qui a rotolarci nella mota, specifica un percorso assoluto e sei a posto. Tipo: "C:\\Documents and Settings\\edpsam\\Desktop\\Progetti JAVA\\dati.xml" al posto di "dati.xml" Questo non si deve fare in un contesto reale ma a te interessa, credo, acquisire dimestichezza con la manipolazione di documenti xml in Java.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me! |
![]() |
![]() |
![]() |
#7 | |
Senior Member
Iscritto dal: Jun 2005
Città: CH
Messaggi: 1058
|
Quote:
per funzionare funziona ![]() |
|
![]() |
![]() |
![]() |
#8 |
Senior Member
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
|
Come prima istruzione del metodo main metti:
System.out.println(System.getProperty("user.dir")); Il percorso che viene stampato sulla console è quello della cartella di lavoro. Quel percorso è la base rispetto a cui è risolto il nome del file. Comunque, ribadisco, questa risoluzione dei percorsi relativi rispetto alla cartella di lavoro è una questione che affronti solo in via sperimentale. Le applicazioni Java, ma non solo, hanno altri mezzi per accedere a risorse esterne che si trovino sul filesystem.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me! |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 20:54.