1

私の質問は、「DOM パーサー、要素の子を 1 つだけ取得するのはなぜですか?」です。

これこれを調べましたが、要点がわかりません。

私がやろうとしていることは次のとおりです。

XML ファイルがあります (以下の抜粋を参照)。

<POITEM>
   <item>
      <PO_ITEM>00010</PO_ITEM>
      <SHORT_TEXT>ITEM_A</SHORT_TEXT>
      <MATL_GROUP>20010102</MATL_GROUP>
      <AGREEMENT>4600010076</AGREEMENT>
      <AGMT_ITEM>00010</AGMT_ITEM>
      <HL_ITEM>00000</HL_ITEM>
      <NET_PRICE>1.000000000</NET_PRICE>
      <QUANTITY>1.000</QUANTITY>
      <PO_UNIT>EA</PO_UNIT>
   </item>
   <item>
      <PO_ITEM>00020</PO_ITEM>
      <SHORT_TEXT>ITEM_B</SHORT_TEXT>
      <MATL_GROUP>20010102</MATL_GROUP>
      <AGREEMENT>4600010080</AGREEMENT>
      <AGMT_ITEM>00020</AGMT_ITEM>
      <HL_ITEM>00000</HL_ITEM
      <NET_PRICE>5.000000000</NET_PRICE>
      <QUANTITY>5.000</QUANTITY>
      <PO_UNIT>EA</PO_UNIT>
   </item>
</POITEM>

<PO_ITEM>, <SHORT_TEXT>, <MATL_GROUP>, <NET_PRICE>, <QUANTITY>私はそれを抽出し<PO_UNIT>て、別の小さな XML ファイルに書き込みたいだけです。

これは私のコードです:

nodes = dcmt.getElementsByTagName("POITEM");

Element rootElement2 = doc1.createElement("PO_POSITIONS");
rootElement1.appendChild(rootElement2);

Element details2 = doc1.createElement("PO_DETAILS");
rootElement2.appendChild(details2);

for (int i = 0; i < nodes.getLength(); i++) {
    Node node = nodes.item(i);
    if (node.getNodeType() == Node.ELEMENT_NODE) {
        Element element = (Element) node;

        Element position = doc1.createElement("position");
        details2.appendChild(position);

        Element poItm = doc1.createElement("PO_ITEM");
        poItm.appendChild(doc1.createTextNode(getValue("PO_ITEM", element)));
        position.appendChild(poItm);

        Element matlGrp = doc1.createElement("MATL_GROUP");
        matlGrp.appendChild(doc1.createTextNode(getValue("MATL_GROUP",element)));
        position.appendChild(matlGrp);

        Element poUnit = doc1.createElement("PO_UNIT");
        poUnit.appendChild(doc1.createTextNode(getValue("PO_UNIT",element)));
        position.appendChild(poUnit);

        Element netPrice = doc1.createElement("NET_PRICE");
        netPrice.appendChild(doc1.createTextNode(getValue("NET_PRICE",element)));
        position.appendChild(netPrice);

        Element shortTxt = doc1.createElement("SHORT_TEXT");
        shortTxt.appendChild(doc1.createTextNode(getValue("SHORT_TEXT",element)));
        position.appendChild(shortTxt);

        //Element matl = doc2.createElement("MATERIAL");
        //matl.appendChild(doc2.createTextNode(getValue("MATERIAL",element)));
        //details2.appendChild(matl);

        Element qnty = doc1.createElement("QUANTITY");
        qnty.appendChild(doc1.createTextNode(getValue("QUANTITY",element)));
        position.appendChild(qnty);

        /*Element preqNr = doc1.createElement("PREQ_NO");
          preqNr.appendChild(doc1.createTextNode(getValue("PREQ_NO",element)));
          details2.appendChild(preqNr); */
    }
}

これまでのところ、新しい XML ファイルを取得していますが、最初のエントリしか保持していないため、最初のエントリまでnodes = dcmt.getElementsByTagName("POITEM");取得 してからループから抜け出します。では、次の項目へのステップインを管理するにはどうすればよいでしょうか? 次の にアクセスするには、ある種のループを作成する必要がありますか? ところで、インターフェイスからファイルを取得するため、XML ファイルの構造を変更することはできません。それとも、新しい XML ファイルを書き間違えたのでしょうか?<item></item><item>

出力は次のようになります。

<PO_POSITIONS>
  <PO_DETAILS>
    <position>
      <PO_ITEM>00010</PO_ITEM>
      <MATL_GROUP>20010102</MATL_GROUP>
      <PO_UNIT>EA</PO_UNIT>
      <NET_PRICE>1.00000000</NET_PRICE>
      <SHORT_TEXT>ITEM_A</SHORT_TEXT>
      <QUANTITY>1.000</QUANTITY>
    </position>
  </PO_DETAILS>
</PO_POSITIONS>
4

1 に答える 1

1

自分で解析できますが、ちょっと面倒です。私が xml を使っていた頃は、スタイルシートを使用してこれらの種類の変換を行っていました。この投稿のようなもの: Java を使用して XSL で XML を変換する方法

それができない場合は、手動で行います (新しいドキュメントの作成は省略しましたが、どこに行くかを確認できます)。

import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.junit.Test;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class XMLTest { 
    @Test
    public void testXmlParsing() throws Exception {
        DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
        DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
        Document doc = dBuilder.parse(new File("/Users/aakture/Documents/workspace-sts-2.9.1.RELEASE/smartfox/branches/trunk/java/gelato/src/test/resources/sample.xml").getAbsolutePath());
        Node poItem = doc.getElementsByTagName("POITEM").item(0);
        NodeList poItemChildren = poItem.getChildNodes();
        for (int i = 0; i < poItemChildren.getLength(); i++) {
            Node item = poItemChildren.item(i);
            NodeList itemChildren = item.getChildNodes();
            for (int j = 0; j < itemChildren.getLength(); j++) {
                Node itemChild = itemChildren.item(j);
                if("PO_ITEM".equals(itemChild.getNodeName())) {
                    System.out.println("found PO_ITEM: " +     itemChild.getTextContent());
                }
                if("MATL_GROUP".equals(itemChild.getNodeName())) {
                    System.out.println("found MATL_GROUP: " + itemChild.getTextContent());
                }

            }
        }
    }
}
于 2013-07-31T20:31:14.907 に答える