2012-03-05 14 views
-2

xmlパーサーを作成しようとしていますが、ファイルからデータを抽出するときに問題が発生しているようです。いくつかのチュートリアルを読んだ後(Java XML Parser問題

<bug> 
     <fields> 
      <field name="ID">test</field> 
      <field name="Summary"></field> 
      <field name="Customer Importance">Unspecified</field> 
      <field name="Development Order">Unspecified</field> 
      <field name="Created Date">Mon Mar 05 03:41:46 EST 2012</field> 
      <field name="Activity">Production</field> 
      <field name="State">Triage</field> 
      <field name="Date Closed"/> 
      <field name="Date Found">Mon Mar 05 00:00:00 EST 2012</field> 
      <field name="Issue Type">Software Report</field> 
      <field name="Reason">Triage</field> 
      <field name="Description">Subject:</field> 
     </fields> 
    </bug> 

と私が書いている:

Root Element: integrity_bug_data 
Getting Tage Value for: id 
java.lang.NullPointerException 

このファイルは次のようになります。私は私が呼ぶ1回目のJava nullポインタ例外に実行し続けるには、タグ値を取得します)この:

try{ 
     ArrayList<String> idData = new ArrayList<>(), sumryData = new ArrayList<>(), descpData = new ArrayList<>() ; 

      //Load the XML File 
     DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance(); 
     DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder(); 
     org.w3c.dom.Document doc = docBuilder.parse(new File("./Data.xml")); 

     System.out.println("Root Element: "+doc.getDocumentElement().getNodeName()); 

     NodeList bugList = doc.getElementsByTagName("bug"); 

     for (int i = 0; i < bugList.getLength(); i++){ 
      Node nNode = bugList.item(i); 


      if(nNode.getNodeType() == Node.ELEMENT_NODE){ 
       Element eElement = (Element) nNode; 

       idData.add(getTagValue("id",eElement)); 
       System.out.print("ID: "+getTagValue("id",eElement)); 


       String sumry = getTagValue("Summary",eElement); 
       System.out.println("NodeList: "+sumry); 

       String nstr = sumry.replace("\n", " "); 
       String ustr = nstr.replaceAll(":", ""); 
       nstr = ustr.replace(",", " "); 

       sumryData.add(nstr); 
       System.out.print("Summary: "+nstr); 


       String desc = getTagValue("Description",eElement); 
       System.out.println("NodeList: "+desc); 

       nstr = desc.replace("\n", " "); 
       ustr = nstr.replaceAll(":", ""); 
       nstr = ustr.replace(",", " "); 

       descpData.add(nstr); 
       System.out.print("Description: "+nstr); 
      } 
     } 

    public static String getTagValue(String tag, Element eElement){ 
     System.out.println("Getting Tage Value for: "+tag); 
     NodeList n1List = eElement.getElementsByTagName(tag).item(0).getChildNodes(); 
     Node nValue = (Node) n1List.item(0); 
     return nValue.getNodeValue(); 
    }  

は問題が <field name"..."></field>

としなければならないだろう

は、どこで私が<id>, <summary> etc...のために読んでいると想定されていますか?助けを事前に

おかげで...

+1

問題は何ですか? – Overv

+0

sry更新しました – Shahab

+0

getTagValue( "id"、eElement)を大文字の "ID"で試しましたか? – dyrkin

答えて

1

はルックス:

public static String getTagValue(String tag, Element eElement) { 
    System.out.println("Getting Tage Value for: " + tag); 
    NodeList n1List = eElement.getElementsByTagName("field"); 
    for (int i = 0; i < n1List.getLength(); i++) { 
     Node nNode = n1List.item(i); 
     if (((Element) nNode).getAttribute("name").equalsIgnoreCase(tag)) { 
      return nNode.getTextContent(); 
     } 
    } 
    return null; 
} 
+0

ありがとう、私は属性が必要! – Shahab

1

<bug>は何<id>要素が含まれていない場合、または<id>タグは子ノードを持たない場合に発生することができます。 getTagValue()にはどちらの可能性も許されませんでした。

+0

彼らはすべて ...を持っています。どのように私はそれを解析するだろうか? – Shahab

+0

フィールドを検索すると、属性は名前になりますか? – Shahab

1

あなたの問題が書かれていないので、コードでお手伝いできません。しかし、私はこのXMLを解析するのを助けることができます。私は解析のためにJAXBを使うことをお勧めします。

JAXBContext ctx = JAXBContext.newInstance("com.panpwr.api.model.deployment"); 
Unmarshaller unmarshaller = ctx.createUnmarshaller(); 
Data data = (Data)unmarshaller.unmarshal(in); // in is the input stream for XML 
// now your instance of data is populated from XML 

それだこと:今、次のようなコードを書く

@XmlRootElement 
public class Bug { 
    private Collection<Field> fields; 

    @XmlElementWrapper(name = "cars") 
    @XmlElement(name = "car")  
    public Collection<Field> getFields() { 
     return fields; 
    } 
    // other methods.... 
} 


public class Field { 
    private Sting name; 
    private String text; 

    @XmlAttribute 
    public String getName() { 
     return name; 
    } 
    @XmlValue 
    public String getText() { 
     return text; 
    } 

} 

:あなたがここに必要な唯一のものは、クラスBugを作成することです。あなたは完了です。これは問題なくXMLを解析します。あなたはこのような何かにあなたのgetTagValue方法を変更する必要があるよう