当前位置: 首页 > news >正文

青岛网站关键词国外服务器免备案

青岛网站关键词,国外服务器免备案,除了阿里巴巴还有什么网站做外贸的,织梦网站地图修改转载自 JAXP操作xmlDOM对象详解1#xff0e;基本的DOM对象 DOM的基本对象有5个#xff1a;Document#xff0c;Node#xff0c;NodeList#xff0c;Element和Attr。下面就这些对象的功能和实现的方法作一个大致的介绍。 Document 对象代表了整个XML的文档#xff0c;所…转载自   JAXP操作xmlDOM对象详解1基本的DOM对象 DOM的基本对象有5个DocumentNodeNodeListElement和Attr。下面就这些对象的功能和实现的方法作一个大致的介绍。 Document 对象代表了整个XML的文档所有其它的Node都以一定的顺序包含在Document对象之内排列成一个树形的结构程序员可以通过遍历这颗树来得 到XML文档的所有的内容这也是对XML文档操作的起点。我们总是先通过解析XML源文件而得到一个Document对象然后再来执行后续的操作。此 外Document还包含了创建其它节点的方法比如createAttribut()用来创建一个Attr对象。它所包含的主要的方法有 createAttribute(String)用给定的属性名创建一个Attr对象并可在其后使用setAttributeNode方法来放置在某一个Element对象上面。 createElement(String)用给定的标签名创建一个Element对象代表XML文档中的一个标签然后就可以在这个Element对象上添加属性或进行其它的操作。 createTextNode(String)用给定的字符串创建一个Text对象Text对象代表了标签或者属性中所包含的纯文本字符串。如果在一个标签内没有其它的标签那么标签内的文本所代表的Text对象是这个Element对象的唯一子对象。 getElementsByTagName(String)返回一个NodeList对象它包含了所有给定标签名字的标签。 getDocumentElement()返回一个代表这个DOM树的根节点的Element对象也就是代表XML文档根元素的那个对象。 Node 对象是DOM结构中最为基本的对象代表了文档树中的一个抽象的节点。在实际使用的时候很少会真正的用到Node这个对象而是用到诸如 Element、Attr、Text等Node对象的子对象来操作文档。Node对象为这些对象提供了一个抽象的、公共的根。虽然在Node对象中定义了 对其子节点进行存取的方法但是有一些Node子对象比如Text对象它并不存在子节点这一点是要注意的。Node对象所包含的主要的方法有 appendChild(org.w3c.dom.Node)为这个节点添加一个子节点并放在所有子节点的最后如果这个子节点已经存在则先把它删掉再添加进去。 getFirstChild()如果节点存在子节点则返回第一个子节点对等的还有getLastChild()方法返回最后一个子节点。 getNextSibling()返回在DOM树中这个节点的下一个兄弟节点对等的还有getPreviousSibling()方法返回其前一个兄弟节点。 getNodeName()根据节点的类型返回节点的名称。 getNodeType()返回节点的类型。 getNodeValue()返回节点的值。 hasChildNodes()判断是不是存在有子节点。 hasAttributes()判断这个节点是否存在有属性。 getOwnerDocument()返回节点所处的Document对象。 insertBefore(org.w3c.dom.Node neworg.w3c.dom.Node ref)在给定的一个子对象前再插入一个子对象。 removeChild(org.w3c.dom.Node)删除给定的子节点对象。 replaceChild(org.w3c.dom.Node neworg.w3c.dom.Node old)用一个新的Node对象代替给定的子节点对象。 NodeList对象顾名思义就是代表了一个包含了一个或者多个Node的列表。可以简单的把它看成一个Node的数组我们可以通过方法来获得列表中的元素 GetLength()返回列表的长度。 Item(int)返回指定位置的Node对象。 Element对象代表的是XML文档中的标签元素继承于Node亦是Node的最主要的子对象。在标签中可以包含有属性因而Element对象中有存取其属性的方法而任何Node中定义的方法也可以用在Element对象上面。 getElementsByTagName(String)返回一个NodeList对象它包含了在这个标签中其下的子孙节点中具有给定标签名字的标签。 getTagName()返回一个代表这个标签名字的字符串。 getAttribute(String) 返回标签中给定属性名称的属性的值。在这儿需要主要的是应为XML文档中允许有实体属性出现而这个方法对这些实体属性并不适用。这时候需要用到 getAttributeNodes()方法来得到一个Attr对象来进行进一步的操作。 getAttributeNode(String)返回一个代表给定属性名称的Attr对象。 Attr 对象代表了某个标签中的属性。Attr继承于Node但是因为Attr实际上是包含在Element中的它并不能被看作是Element的子对象因 而在DOM中Attr并不是DOM树的一部分所以Node中的getparentNode()getdivviousSibling()和 getnextSibling()返回的都将是null。也就是说Attr其实是被看作包含它的Element对象的一部分它并不作为DOM树中单独 的一个节点出现。这一点在使用的时候要同其它的Node子对象相区别。 需要说明的是上面所说的DOM对象在DOM中都是用接口定义的 DOM其实可以在任何面向对象的语言中实现只要它实现了DOM所定义的接口和功能就可以了。 2关于JAXP包JAXP 开发包是J2SE的一部分它由javax.xml、org.w3c.dom 、org.xml.sax 包及其子包组成在 javax.xml.parsers 包中定义了几个工厂类程序员调用这些工厂类可以得到对xml文档进行解析的 DOM 或 SAX 的解析器对象。 使用JAXP进行DOM解析 javax.xml.parsers包中的DocumentBuilderFactory用于创建DOM模式的解析器对象 DocumentBuilderFactory是一个抽象工厂类它不能直接实例化但该类提供了一个newInstance方法 这个方法会根据本地平台默认安装的解析器自动创建一个工厂的对象并返回。 获得JAXP中的DOM解析器 调用 DocumentBuilderFactory.newInstance() 方法得到创建 DOM 解析器的工厂。 调用工厂对象的 newDocumentBuilder方法得到 DOM 解析器对象。 调用 DOM 解析器对象的 parse()方法解析 XML 文档得到代表整个文档的 Document 对象进行可以利用DOM特性对整个XML文档进行操作了。 更新XML文档javax.xml.transform包中的Transformer类用于把代表XML文件的Document对象转换为某种格式后进行输出例如把xml文件应用样式表后转成一个html文档。利用这个对象当然也可以把Document对象又重新写入到一个XML文件中。 Transformer类通过transform方法完成转换操作该方法接收一个源和一个目的地。我们可以通过 •        javax.xml.transform.dom.DOMSource类来关联要转换的document对象 •        用javax.xml.transform.stream.StreamResult 对象来表示数据的目的地。Transformer对象通过TransformerFactory获得。 看一个简单示例 Book.xml ?xmlversion1.0encodingUTF-8standaloneno? book booknameJava程序设计/bookname bookprice40元/bookprice authorlijizh/author publisherlijizh1013/publisher /bookDom.java package dtd;import java.io.IOException; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; importjavax.xml.parsers.ParserConfigurationException;import org.w3c.dom.Document; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import org.xml.sax.SAXException;publicclass Dom {publicstaticvoid main(String[] args) throws ParserConfigurationException,SAXException, IOException {//获取解析工厂DocumentBuilderFactory dbf DocumentBuilderFactory.newInstance();//创建解析器对象DocumentBuilder db dbf.newDocumentBuilder();//获取Document对象Document d db.parse(src/dtd/Book.xml);//通过Document对象的方法获取相应的节点列表NodeList nl d.getElementsByTagName(bookname);//获取指定节点Node node nl.item(0);//获取指定节点内容String content node.getTextContent();//输出内容System.out.println(content);} } 示例完成对XML文件的CRUD操作 Book.xml ?xmlversion1.0encodingUTF-8standaloneno? book booknameJava程序设计/bookname bookprice40元/bookprice authorlijizh/author publisherlijizh1013/publisher /book ReadDom.java package dtd;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.junit.Test; 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;publicclass ReadDom {Testpublicvoid read() throws ParserConfigurationException, SAXException, IOException{DocumentBuilderFactoryfactory DocumentBuilderFactory.newInstance();DocumentBuilder db factory.newDocumentBuilder();Document d db.parse(src/dtd/Book.xml);Node node d.getElementsByTagName(book).item(0);// System.out.println(node.getNodeName());list(node); }//用此方法遍历元素节点 private void list(Node node) {if(node instanceof Element){System.out.println(node.getNodeName());}NodeList list node.getChildNodes();for(int i 0;i list.getLength();i){Node node1 list.item(i);list(node1);}}Test//以尾部追加的方式向XML文件中增添数据的方法public void insert() throws ParserConfigurationException, SAXException,IOException, TransformerException{DocumentBuilderFactory factory DocumentBuilderFactory.newInstance();DocumentBuilderdb factory.newDocumentBuilder();Document d db.parse(src/dtd/Book.xml); Element node (Element)d.getElementsByTagName(book).item(0);Element newNode d.createElement(color);newNode.setTextContent(red);node.appendChild(newNode);//通过转换工厂的newInstance()方法获取工厂实例TransformerFactory tff TransformerFactory.newInstance();//获取转换器Transformer tf tff.newTransformer();//通过转换器对象的transform方法将源与目标文件相连接tf.transform(new DOMSource(d),new StreamResult(src/dtd/Book.xml)); }Test//以向前插入的方式向XML文件中增添数据的方法publicvoid insert1() throws ParserConfigurationException, SAXException, IOException,TransformerException{DocumentBuilderFactory factory DocumentBuilderFactory.newInstance();DocumentBuilder db factory.newDocumentBuilder();Document d db.parse(src/dtd/Book.xml);Element node (Element)d.getElementsByTagName(book).item(0);Element newNode d.createElement(publisher);newNode.setTextContent(lijizh);Element refChild (Element)d.getElementsByTagName(color).item(0);node.insertBefore(newNode, refChild);TransformerFactory tff TransformerFactory.newInstance();Transformer tf tff.newTransformer();tf.transform(new DOMSource(d),new StreamResult(src/dtd/Book.xml));}Test//从XML文件中删除数据的方法publicvoid delete() throws ParserConfigurationException, SAXException, IOException,TransformerException{DocumentBuilderFactory factory DocumentBuilderFactory.newInstance();DocumentBuilder db factory.newDocumentBuilder();Document d db.parse(src/dtd/Book.xml);Element node (Element)d.getElementsByTagName(color).item(0);Element parent (Element)node.getParentNode();parent.removeChild(node);TransformerFactory tff TransformerFactory.newInstance();Transformer tf tff.newTransformer();tf.transform(new DOMSource(d),new StreamResult(src/dtd/Book.xml));}Test从XML文件中更新数据的方法publicvoid update() throws ParserConfigurationException, SAXException, IOException,TransformerException{DocumentBuilderFactory factory DocumentBuilderFactory.newInstance();DocumentBuilder db factory.newDocumentBuilder();Document d db.parse(src/dtd/Book.xml);Element node (Element)d.getElementsByTagName(publisher).item(0);node.setTextContent(lijizh1013); TransformerFactory tff TransformerFactory.newInstance();Transformer tf tff.newTransformer();tf.transform(new DOMSource(d),new StreamResult(src/dtd/Book.xml));}}}
http://www.pierceye.com/news/687229/

相关文章:

  • 线上渠道推广网站的优化哪个好
  • 群晖可以做网站服务器微信朋友圈怎么发链接那种网页怎么制作
  • wordpress 公司网站网站和公众号的区别
  • 数据库跟网站seo流程
  • 网站首页关键词设置网站的整体风格
  • wordpress源码站整站源码制作wordpress插件
  • 海口网站建设就q479185700上墙网站空间后台怎么进入
  • 四川电子有限公司 - 手机网站如何做网站家具导购
  • 网站经营性备案修改wordpress自带小工具
  • 网站怎么建设可以发图评论网站建设制作公
  • 做销售的网站设计公司是做什么的
  • 建设专业网站的利弊海淀区seo招聘信息
  • 吴江区住房与建设局网站网站开发怎么对接客户
  • frontpage2007网站建设网站开发需要redis
  • 国内做网站多少钱ui中有哪些做的好看的网站
  • 金湖建设工程质量监督网站网页设计 网站建设 哪个好
  • 适合做外链的网站梧州论坛红豆思辨
  • 永城网站设计公司wordpress 获取父分类
  • 网站开发语言是什么东莞营销网站建设价格
  • 外贸公司访问国外网站中学生做的网站有哪些方面
  • 南城网站建设公司信息wordpress怎样显示文章全部列表
  • 做推广什么网站便宜企业网站管理系统湖南岚鸿
  • 电影下载网站 怎么做flash翻页效果网站模板
  • 社交网站开发语言河北建设工程信息网首页
  • 上海营销型网站建设公司wordpress 自己做页面
  • 网站布局选择临淄信息网手机版
  • 怎样申请网站呢注册商标怎么注册商标
  • 网站地址英文不相关的网站做单项链接可以吗
  • 怎么做网站超链接wordpress 主题 设置
  • 手机电影网站建设如何做网站域名备案