遍历元素属性节点实例
2011-11-08 11:49
218 查看
package csdn.xml.dom;
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.Attr;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Text;
import java.io.File;
public class MyDomTest {
public static void main(String[] args) throws Exception {
//获得工厂对象
DocumentBuilderFactory factory =
DocumentBuilderFactory.newInstance();
//获得解析器
DocumentBuilder builder = factory.newDocumentBuilder();
//进行解析,获得Document对象
Document doc = builder.parse(new File("src/book.xml"));
//顺序访问节点的方式找到书架节点
// NodeList nodeList = doc.getChildNodes().item(0).getChildNodes();
// System.out.println("书架的子节点数量:"+nodeList.getLength());
//随机访问已知元素名称的指定节点
// NodeList nodeList = doc.getElementsByTagName("书架");
// Node node = nodeList.item(0);
// listAllNodes(node);
//插入新节点
// createNode(doc);
//在指定位置前插入新节点
insertFixedNode(doc);
}
//对指定的节点进行遍历
public static void listAllNodes(Node node){
System.out.println("节点名:"+node.getNodeName()
+ " 节点值: "+node.getNodeValue());
if(node.getNodeType() == Node.ELEMENT_NODE){
//遍历当前元素节点的属性
if(node.hasAttributes()){
NamedNodeMap attrs = node.getAttributes();
for(int i=0; i<attrs.getLength(); i++){
Node attrNode = attrs.item(i);
System.out.println(attrNode.getNodeName() +
" : "+attrNode.getNodeValue());
}
}
//遍历当前元素节点的子结点,利用递归实现
if(node.hasChildNodes()){
NodeList nodeList = node.getChildNodes();
for(int i=0; i<nodeList.getLength(); i++){
Node childNode = nodeList.item(i);
listAllNodes(childNode); //递归
}
}
}
}
public static void createNode(Document doc) throws TransformerException{
Node node = doc.getElementsByTagName("书").item(1);
Element element = doc.createElement("出版社");
element.setTextContent("西安交大出版社");
node.appendChild(element);
TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer();
transformer.transform(new DOMSource(doc), new StreamResult(new File("src/book.xml")));
}
public static void insertFixedNode(Document doc) throws Exception{
Node secBookNode = doc.getElementsByTagName("书").item(1);
Node priceNode = secBookNode.getChildNodes().item(4);
Element isbnElement = doc.createElement("ISBN");
Text isbnText = doc.createTextNode("123-345-333");
isbnElement.appendChild(isbnText);
// secBookNode.appendChild(isbnElement); //追加为secBookNode最后一个子结点
//插入到售价节点之前
secBookNode.insertBefore(isbnElement, priceNode);
TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer();
transformer.transform(new DOMSource(doc), new StreamResult(new File("src/book.xml")));
}
}
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.Attr;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Text;
import java.io.File;
public class MyDomTest {
public static void main(String[] args) throws Exception {
//获得工厂对象
DocumentBuilderFactory factory =
DocumentBuilderFactory.newInstance();
//获得解析器
DocumentBuilder builder = factory.newDocumentBuilder();
//进行解析,获得Document对象
Document doc = builder.parse(new File("src/book.xml"));
//顺序访问节点的方式找到书架节点
// NodeList nodeList = doc.getChildNodes().item(0).getChildNodes();
// System.out.println("书架的子节点数量:"+nodeList.getLength());
//随机访问已知元素名称的指定节点
// NodeList nodeList = doc.getElementsByTagName("书架");
// Node node = nodeList.item(0);
// listAllNodes(node);
//插入新节点
// createNode(doc);
//在指定位置前插入新节点
insertFixedNode(doc);
}
//对指定的节点进行遍历
public static void listAllNodes(Node node){
System.out.println("节点名:"+node.getNodeName()
+ " 节点值: "+node.getNodeValue());
if(node.getNodeType() == Node.ELEMENT_NODE){
//遍历当前元素节点的属性
if(node.hasAttributes()){
NamedNodeMap attrs = node.getAttributes();
for(int i=0; i<attrs.getLength(); i++){
Node attrNode = attrs.item(i);
System.out.println(attrNode.getNodeName() +
" : "+attrNode.getNodeValue());
}
}
//遍历当前元素节点的子结点,利用递归实现
if(node.hasChildNodes()){
NodeList nodeList = node.getChildNodes();
for(int i=0; i<nodeList.getLength(); i++){
Node childNode = nodeList.item(i);
listAllNodes(childNode); //递归
}
}
}
}
public static void createNode(Document doc) throws TransformerException{
Node node = doc.getElementsByTagName("书").item(1);
Element element = doc.createElement("出版社");
element.setTextContent("西安交大出版社");
node.appendChild(element);
TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer();
transformer.transform(new DOMSource(doc), new StreamResult(new File("src/book.xml")));
}
public static void insertFixedNode(Document doc) throws Exception{
Node secBookNode = doc.getElementsByTagName("书").item(1);
Node priceNode = secBookNode.getChildNodes().item(4);
Element isbnElement = doc.createElement("ISBN");
Text isbnText = doc.createTextNode("123-345-333");
isbnElement.appendChild(isbnText);
// secBookNode.appendChild(isbnElement); //追加为secBookNode最后一个子结点
//插入到售价节点之前
secBookNode.insertBefore(isbnElement, priceNode);
TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer();
transformer.transform(new DOMSource(doc), new StreamResult(new File("src/book.xml")));
}
}
相关文章推荐
- 遍历整个html文档 并打印出该html文档中的所有文本节点 属性节点 元素节点
- js遍历子节点子元素附属性及方法
- DOM中元素节点、属性节点、文本节点的理解
- JQ 遍历节点 取得元素集合 前面同辈 后面同辈 前后所有同辈 最近匹配
- 分析 line-height属性&行框模型&行替换元素空白节点
- ztree 遍历获取所需节点属性
- DOM中元素节点、属性节点、文本节点的理解
- 认识DOM的三大节点:元素节点,文本节点,属性节点以及nodeName,nodeType,nodeValue的区别
- jQuery元素属性操作实例(设置、获取及删除元素属性)
- js 获取元素所有兄弟节点实例
- C#加载XML文件,遍历所有的元素和属性匹配
- Dom4j解析xml文件-递归遍历所有节点和属性
- DOM中元素节点、属性节点、文本节点的理解
- DOM遍历元素节点时忽略空格文本节点的方法
- java 使用foreach遍历集合元素的实例
- 从dts文件中获取节点和属性的实例一
- JQuery_dom属性操作、节点遍历及包裹
- 遍历DOM的所有节点,输出宽度高度都大于50的元素节点名称
- js 获取元素所有兄弟节点实例