XML解析

解析xml实例

package com.xaccp;

import java.io.File;
import java.io.IOException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

//测试类

public class Test {

public static void main1(String[] args) {
  try {
   DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
   DocumentBuilder db=dbf.newDocumentBuilder();
   Document doc=db.parse(new File("e:/config.xml"));//在e:盘建立一个config.xml文件
   Element root=doc.getDocumentElement();//得到根节点
   NodeList nl=root.getChildNodes();//得到根节点下的所有子节点

//便利
   for (int i = 0; i < nl.getLength(); i++) {
    Node node=nl.item(i);

//如果该节点的类型是一个元素的话,就继续
    if (node.getNodeType()==Node.ELEMENT_NODE)
    {
       Element e=(Element) node;
       String key=e.getAttribute("key");//根据键得到属性
       NodeList mydsItems=e.getChildNodes();//得到所有e下的子节点

//便利
       for (int j = 0; j < mydsItems.getLength(); j++) {
      Node item=mydsItems.item(j);
      if (item instanceof Element)
      {
        Element is=(Element) item;
        String value=is.getLastChild().getNodeValue();//得到值
        System.out.println(value);
      }
     }
    }
   }
//   System.out.println(root.getChildNodes().getLength());
  } catch (ParserConfigurationException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SAXException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
}
}
建立一个config.xml 如:

<?xml version="1.0" encoding="UTF-8"?>
<config>
    <dataSource key="myds">
              <driver>com.microsoft.jdbc.sqlserver.SQLServerDriver</driver>
     <url>jdbc:microsoft:sqlserver://localhost:1433;databaseName=pubs</url>
     <user>sa</user>
      <pass> </pass>
</dataSource>
</config>


你可能感兴趣的:(xml,jdbc,Microsoft,J#)