xml:
<?xml version="1.0" encoding="UTF-8" standalone="no"?><person>
<p1>
<name>lqw</name>
<age>20</age>
<sex>nv</sex>
</p1>
<p2>
<name>pcl</name>
<age>26</age>
</p2>
</person>
要求:打印出xml中所有元素名称
思路:
1.创建解析器工厂
2.通过解析器工厂创建解析器
3.解析xml文档返回document
4.得到根节点
5.得到根节点子节点
6.得到根节点子节点的子节点(4-6可以使用递归实现)
7.xml解析会把空格换行都当成内容解析,所以需要判断是元素类型时再打印
代码:
package cn.itcast.jasptest;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.w3c.dom.Text;
import org.xml.sax.SAXException;
public class Test {
public static void main(String[] args) throws ParserConfigurationException, IOException, SAXException, TransformerException {
listElement();
}
public static void listElement() throws ParserConfigurationException, IOException, SAXException, TransformerException {
DocumentBuilderFactory builderFactory=DocumentBuilderFactory.newInstance();
DocumentBuilder builder=builderFactory.newDocumentBuilder();
Document document=builder.parse("src/1.xml");
digui(document);
}
public static void digui(Node node) {
if(node.getNodeType()==node.ELEMENT_NODE)
System.out.println(node.getNodeName());
NodeList list=node.getChildNodes();
for(int i=0;i<list.getLength();i++) {
Node node1=list.item(i);
digui(node1);
}
}
}