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

2019深圳网站设计公司排名wordpress the7 theme

2019深圳网站设计公司排名,wordpress the7 theme,群晖 搭建wordpress,免费自助建站代理1 在Java中解析XML文件共有四种方式 A、DOM方式解析XML数据 树结构#xff0c;有助于更好地理解、掌握#xff0c;代码易于编写#xff0c;在解析过程中树结构是保存在内存中#xff0c;方便修改 B、SAX方式解析 采用事件驱动模式#xff0c;对内存消耗比较小#xff0…1 在Java中解析XML文件共有四种方式 A、DOM方式解析XML数据 树结构有助于更好地理解、掌握代码易于编写在解析过程中树结构是保存在内存中方便修改 B、SAX方式解析 采用事件驱动模式对内存消耗比较小适用于仅处理xml中的数据时使用 C、JDOM方式解析 大量采用了 Collections 类 D、DOM4J方式解析 JDOM的一种智能分支合并了许多超出基本XML文档表示的功能 性能优越灵活性好功能强大极端易用。 2 要处理的XML文件 ?xml version1.0 encodingUTF-8? books xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancebook id1001nameJAVA 高级编程/nameauthor张三/authorprice85.72/price/bookbook id1002nameC和C#/nameauthor李失失/authorprice125.73/price/book /books 3 DOM方式解析XML数据的步骤 a. 创建一个DocumentBuilderFactory对象 b. 创建一个DocumentBuilder对象 c. 通过DocumentBuilder的parse()方法得到Document对象 d. 通过getElementsByTagName()方法获取节点的列表 e. 使用for循环遍历节点 f. 得到所有节点的属性和属性值 g. 得到所有节点的节点名和节点值 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.NamedNodeMap; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import org.xml.sax.SAXException;public class TestDom4Xml {public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {//创建一个DocumentBuilderFactory对象DocumentBuilderFactory dbf DocumentBuilderFactory.newInstance();//创建一个DocumentBuilder对象DocumentBuilder db dbf.newDocumentBuilder();//通过DocumentBuilder的parse()方法得到Document对象Document doc db.parse(book.xml);//通过getElementsByTagName()方法获取节点的列表NodeList nodelist doc.getElementsByTagName(book);System.out.println(nodelist.getLength());//使用for循环遍历节点for(int i0;inodelist.getLength();i){Node node nodelist.item(i);//得到所有节点属性和属性值的对象NamedNodeMap nnm node.getAttributes();for(int j0;jnnm.getLength();j){Node sub_node nnm.item(j);//得到所有节点的属性和属性值System.out.println(sub_node.getNodeName() : sub_node.getNodeValue());}//得到所有节点的子节点NodeList childlist node.getChildNodes();for(int j0;jchildlist.getLength();j){Node sub_node childlist.item(j);//获取节点类型short type sub_node.getNodeType();//判断节点类型是否不为#text因会将前一标签的末尾与下一标签的开头之间的字符标记为#text//因此这里需要进行判断if(type Node.ELEMENT_NODE){//得到所有节点的节点名和节点值System.out.println(sub_node.getNodeName() : sub_node.getTextContent());}}}} } 输出结果如下 2 id : 1001 name : JAVA 高级编程 author : 张三 price : 85.72 id : 1002 name : C和C# author : 李失失 price : 125.73 4 SAX方式解析XML文件 4.1 创建DeaultHandler子类用来解析XML文档 import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler;public class BookDefaultHandler extends DefaultHandler {/*** 解析xml文档时调用*/public void startDocument() throws SAXException {System.out.println(开始解析XML文档);super.startDocument();}/*** 解析xml文档结束时调用*/public void endDocument() throws SAXException {super.endDocument();System.out.println(完成解析XML文档);}/*** 解析XML文档节点开始时使用*/public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {super.startElement(uri, localName, qName, attributes);//判断如果是 book节点获取节点属性和属性值if(qName.equals(book)){//获取当前属性的数量int len attributes.getLength();//循环获取每个属性for(int i0;ilen;i){//属性名称String name attributes.getQName(i);//属性值String value attributes.getValue(i);System.out.println(属性名称 name \t属性值 value);}}else if(!books.equals(qName) !book.equals(qName)){System.out.print(节点的名称 qName \t);}}/*** 解析XML文档节点结束时使用*/public void endElement(String uri, String localName, String qName) throws SAXException {super.endElement(uri, localName, qName);}/*** 解析节点文本内容*/public void characters(char[] ch, int start, int length) throws SAXException {super.characters(ch, start, length);//将节点文本转为字符串String value new String(ch, start, length);//排除空数据并输出节点文本if(!.equals(value.trim())){System.out.println(value);}} } 4.2 SAX方式解析XML数据的步骤 a. 创建SAXParserFactory对象 b. 创建SAXParser对象(作为解析器) c. 创建DefaultHandler子类对象 d. 调用parse方法 import java.io.IOException; import javax.xml.parsers.ParserConfigurationException; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; import org.xml.sax.SAXException;public class TestSax4Xml {public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {//a. 创建SAXParserFactory对象SAXParserFactory spf SAXParserFactory.newInstance();//b. 创建SAXParser对象(作为解析器)SAXParser sp spf.newSAXParser();//c. 创建DefaultHandler子类对象BookDefaultHandler bdh new BookDefaultHandler();//d. 调用SAXParser对象的parse方法sp.parse(book.xml, bdh);} } 4.3 输出结果 开始解析XML文档 属性名称 id 属性值 1001 节点的名称name JAVA 高级编程 节点的名称author 张三 节点的名称price 85.72 属性名称 id 属性值 1002 节点的名称name C和C# 节点的名称author 李失失 节点的名称price 125.73 完成解析XML文档 5 JDOM方式解析XML数据 5.1 步骤 a. 创建SAXBuilder对象 b. 调用build方法通过IO流得到Document对象 c. 获取根节点 d. 获取根节点下直接子节点的集合 e. 遍历集合 import java.io.FileInputStream; import java.io.IOException; import java.util.List;import org.jdom2.Attribute; import org.jdom2.Document; import org.jdom2.Element; import org.jdom2.JDOMException; import org.jdom2.input.SAXBuilder;public class TestJdom4Xml {public static void main(String[] args) throws JDOMException, IOException {//a. 创建SAXBuilder对象SAXBuilder sb new SAXBuilder();//b. 调用build方法通过OI流得到Document对象Document doc sb.build(new FileInputStream(src/book.xml));//c. 获取根节点Element root doc.getRootElement();//d. 获取根节点下直接子节点的集合ListElement books root.getChildren();//e. 遍历集合获取每一个子节点for(int i0;ibooks.size();i){//获取集合中的元素Element book books.get(i);//获取当前节点下的属性集合ListAttribute atts book.getAttributes();for(int j0;jatts.size();j){//输出属性名称属性值System.out.println(atts.get(j).getName() \t atts.get(j).getValue());}//获取当前节点下子节点ListElement subEles book.getChildren();//遍历子节点获取名称和文本值for(Element e : subEles){System.out.println(e.getName() \t e.getValue());}}} } 5.2 输出结果 id 1001 name JAVA 高级编程 author 张三 price 85.72 id 1002 name C和C# author 李失失 price 125.73 6 DOM4J解析XML 6.1 DOM4J解析XML步骤 a. 创建SAXReader对象 b. 调用read方法 c. 获取根节点 d. 通过迭代器遍历直接节点 import java.io.FileInputStream; import java.io.FileNotFoundException; import java.util.Iterator;import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader;public class TestDom4jXml {public static void main(String[] args) throws FileNotFoundException, DocumentException {//a. 创建SAXReader对象SAXReader sr new SAXReader();//b. 调用read方法Document doc sr.read(new FileInputStream(src/book.xml));//c. 获取根节点Element root doc.getRootElement();//d. 通过迭代器遍历直接节点for(IteratorElement iterroot.elementIterator();iter.hasNext();){Element book iter.next();//获取节点下所有属性IteratorAttribute arrts book.attributeIterator();//遍历属性信息while(arrts.hasNext()){Attribute at arrts.next();String name at.getName();String value at.getValue();System.out.println(节点属性 name \t value);}//遍历节点下子节点IteratorElement subele book.elementIterator();//获取子节点下所有节点名称和文本值while(subele.hasNext()){Element node subele.next();System.out.println(node.getName() \t node.getText());}}} } 6.2 输出结果 节点属性id 1001 name JAVA 高级编程 author 张三 price 85.72 节点属性id 1002 name C和C# author 李失失 price 125.73
http://www.w-s-a.com/news/987041/

相关文章:

  • 网站推广设计做哪些设置自动删除的wordpress
  • 东莞东坑网站设计专业网站制作设
  • 网站怎么做现场直播视频成都科技网站建设找
  • 个人网页设计步骤网站没有内容 能做优化吗
  • 专业网站建设公司招聘网站排行榜
  • 网站建设规范方法企业解决方案架构
  • ae做网站导航wordpress门户
  • 重庆市网站备案材料云南做网站
  • 网页设计模板网站免费珠海视窗网
  • 茂名模板建站定制WordPress注册不提示
  • 陕西营销型手机网站建设深圳制作网站服务
  • 受欢迎的锦州网站建设Wordpress 图片左右滑动
  • 湖南优化网站建设线上网站建设需求
  • 建什么类型的网站访问量比较大哪些外包公司比较好
  • php网站地图外贸建站哪家强外贸网站怎么做
  • 宁波五金网站建设中国建筑网官网投诉查询
  • 哪个网站注册域名便宜免费流程图制作网站
  • 潍坊做网站南宁网站seo优化公司
  • 网站建设的基本技术步骤无网站营销
  • 我国旅游网站的建设网站开发 混合式 数据库
  • 淘宝客网站域名家居网站开发项目计划书
  • 网站打不开显示asp苏州注册公司需要多少钱
  • 凡科建站登录官网wordpress主题有什么用
  • 西安双语网站建设怎么做网页动图
  • 宝安自适应网站建设无锡新区企业网站推广
  • 肇庆建设局网站cpanel 安装wordpress
  • 长春启做网站多少怎样换wordpress域名
  • 山西网站建设情况汇总vs2010 c 建设网站
  • 网站推广策划书 精品深圳市住建局和建设局官网
  • 住房和城乡建设部干部学院网站一般做公司网站需要哪几点