-
DOM方式生成的DOM树会驻留在内存中,方便进行增删改查; SAX方式是基于事件驱动的,没有状态性可言,对于已经生成的节点无法再修改;查看全部
-
生成xml方式对比查看全部
-
Alt+Shift+向上键查看全部
-
DOM:基于tree SAX:基于事件 JDOM、DOM4J:基于底层API DOM方便后续改动操作,但比较占用内存,因为是加载整个DOM树在内存中。 SAX是逐步解析和写入的,也就是说在写入时,已经操作完成的写入部分是无法进行修改的,因为SAX是基于事件的,其将某一个标签走完之后是不能走回头路的,没有状态性可言,但SAX的性能是非常高的。 这两种方式的选择中很大一部分判断基于是否对文档进行频繁的修改查看全部
-
/SAX 生成xml // 1.创建一个TransformerFactory类的对象 SAXTransformerFactory tff = (SAXTransformerFactory) SAXTransformerFactory .newInstance(); try { // 2.通过SAXTransformerFactory对象创建一个TransformerHandler对象 TransformerHandler handler = tff.newTransformerHandler(); // 3.通过handler对象创建一个Transformer对象 // Transformer tr = handler.getTransformer(); // // 4.通过Transformer对象对生成的xml文件进行设置 // // 设置xml的编码 // tr.setOutputProperty(OutputKeys.ENCODING, "UTF-8"); // // 设置xml的“是否换行” // tr.setOutputProperty(OutputKeys.INDENT, "yes"); // 5.创建一个Result对象 File f = new File("src/res/newbooks.xml"); if (!f.exists()) { f.createNewFile(); } // 6.创建Result对象,并且使其与handler关联 Result result = new StreamResult(new FileOutputStream(f)); handler.setResult(result);查看全部
-
standalone : 用来表示该文件是否呼叫其它外部的文件。若值是 ”yes” 表示没有呼叫外部文件,即说明当前的xml文件是没有DTD和Schema作为它的相关文档,若值是 ”no” 则表示有呼叫外部文件。 默认值是 “yes”。 DTD:文档类型定义(Document Type Definition)是一套关于标记符的语法规则。查看全部
-
1.通过DocumentBuilderFactory.newInstance()实例一个DocumentBuilderFactory对象dbf。 2.通过dbf.newDocumentBuilder()创建DocumentBuilder对象db,注意捕捉异常 3.通过db.newDocument()创建Document对象document. 4.通过document.createElement("bookstore");创建一个bookstore节点 5.通过document.createElement("book");为bookstore创建一个book节点 6.通过book.setAttribute("id","1");为book添加属性。 7.通过bookstore.appendChild(book);将刚才创建的book节点添加到bookstore根节点中。 8.通过document.appendChild(bookstore),将之前创建的bookstore节点(已经包含了book),添加到dom树中。 所以是 创建document,创建跟节点,创建子节点,为子节点添加属性,再依次把子节点添加到父节点中,最多添加到根节点,添加到dom树中。查看全部
-
7查看全部
-
/设置生成的xml的格式 OutputFormat.createPrettyPrint(); //设置生成的字符不转意 writer.setEscapeText(false);查看全部
-
注意:setResult一定要在startDocument之前,否则报异常 //为节点添加文本, 将book的name字符串转为字符数组,截取0-字符大小的字符 handler.characters(book.getName().toCharArray(), 0, book.getName().length()); void characters(char[] ch, int start, int length)查看全部
-
####一、主要用到的类: 1. SAXTransformerFactory:用于创建TransformerHandler实例 2. TransformerHandler:用于生成解析文档 3. Transformer:用于格式化输出的结果 4. Result:用于保存TransformerHandler产生的结果 ####二、主要的流程 // 创建一个工厂类实例,用于创建Handler实例 SAXTransformerFactory factory = (SAXTransformerFactory)SAXTransformer.newInstance(); // 从工厂实例中获取Handler实例 TransformerHandler handler = factory.newTransformerHandler(); // 创建一个格式化传输器 Transformer transformer = handler.getTransformer(); // 设置输出属性:OutputKeys.IDENNT="yes"表示输出结果带换行 former.setOutputProperty(OutputKeys.IDENNT,"yes"); // 创建转换结果持有器,用于保存Handler输出的结果 Result result = new StreamResult(new File("demo.txt")); // 建立handler与result之间的关联,确保handler处理的结果能正确的保存到result中 handler.setResult(result); // handler处理文档的细节(略)查看全部
-
/SAX 生成xml // 1.创建一个TransformerFactory类的对象 SAXTransformerFactory tff = (SAXTransformerFactory) SAXTransformerFactory .newInstance(); try { // 2.通过SAXTransformerFactory对象创建一个TransformerHandler对象 TransformerHandler handler = tff.newTransformerHandler(); // 3.通过handler对象创建一个Transformer对象 // Transformer tr = handler.getTransformer(); // // 4.通过Transformer对象对生成的xml文件进行设置 // // 设置xml的编码 // tr.setOutputProperty(OutputKeys.ENCODING, "UTF-8"); // // 设置xml的“是否换行” // tr.setOutputProperty(OutputKeys.INDENT, "yes"); // 5.创建一个Result对象 File f = new File("src/res/newbooks.xml"); if (!f.exists()) { f.createNewFile(); } // 6.创建Result对象,并且使其与handler关联 Result result = new StreamResult(new FileOutputStream(f)); handler.setResult(result);查看全部
-
四种生成XML方式对比查看全部
-
XMLOutputter outputer = new XMLOutputter();//创建XMLOutputter对象 outputer.output(doucument,new FileOutputStream(new File("rssnews.xml")))查看全部
-
//设置是否转义,默认值是true,代表转义 xmlWriter.setEscapeText(true);查看全部
举报
0/150
提交
取消