• Java核心技术II读书笔记(三)


    ch2 XML

    SAX解析器

    SAXParserFactory factory = SAXParserFactory.newInstance();

    SAXParser parser = factory.newSAXParser();    //建立SAX解析器对象

    parser.parse(source,handler);  //source可以是文件,URL或者字符串输入流,handle是DefaultHandler的子类

    DefaultHandler handler = new 
        DefaultHandler(){
             public void startElement(String namespaceURI,String lname,String qname, Attributes attrs) throws SAXException{
                  if(lname.equalsIngoreCase("a")&&attrs!=null){
                      for(int i=0;i<attrs.getLength();i++){
                           String aname = attrs.getLocalName(i);
                           if(aname.equalsIgnoreCase("href"))
                               System.out.println(attrs.getValue(i));
                      }
                  }
             }          
        };        

    其中qname参数是prefix:localname这种形式。如果命名空间处理特性打开,那么namespaceURI和lname描述的就是命名空间和本地(非限定)名。
    与DOM一样,命名空间默认是关闭的,调用工厂类的setNamespaceAware方法激活:

    SAXParserFactory factory = SAXParserFactory.newInstnce();

    factory.setNamespaceAware(true);

    SAXParser saxParser = factory.newSAXParser();

    备注:XHTML文件总是以一个DTD引用标签开头,W3C也不情愿提供千万亿次的下载,如果自己不需要验证文件,只需调用:

    factory.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd",false);

    StAX解析器

    3 import java.io.*;
    4 import java.net.*;
    5 import javax.xml.parsers.*;
    6 import org.xml.sax.*;
    7 import org.xml.sax.helpers.*;
    89
    /**
    10 * This program demonstrates how to use a SAX parser. The program prints all hyperlinks of an
    11 * XHTML web page.<br>
    12 * Usage: java SAXTest url
    13 * @version 1.00 2001-09-29
    14 * @author Cay Horstmann
    15 */
    16 public class SAXTest
    17 {
    18 public static void main(String[] args) throws Exception
    19 {
    20     String url;
    21     if (args.length == 0)
    22     {
    23          url = "http://www.w3c.org";
    24          System.out.println("Using " + url);
    25     }
    26     else url = args[0];
    27
    28     DefaultHandler handler = new DefaultHandler()
    29     {
    30         public void startElement(String namespaceURI, String lname, String qname,
    31 Attributes attrs)
    32         {
    33              if (lname.equals("a") && attrs != null)
    34              {
    35                  for (int i = 0; i < attrs.getLength(); i++)
    36                  {
    37                      String aname = attrs.getLocalName(i);
    38                      if (aname.equals("href")) System.out.println(attrs.getValue(i));
    39                      }
    40                  }
    41              }
    42          };
    43
    44          SAXParserFactory factory = SAXParserFactory.newInstance();
    45          factory.setNamespaceAware(true);
    46          factory.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd",
    false);
    47          SAXParser saxParser = factory.newSAXParser();
    48          InputStream in = new URL(url).openStream();
    49          saxParser.parse(in, handler);
    50   }
    51 }

    生成XML

    不带命名空间的文档:

    Document doc = builder.newDocument();  //创建一个空文档

    Element rootElement = doc.createElement(rootName);  //创建文档元素

    Element childElement = doc.createElement(childName);

    Text textNode = doc.createTextNode(textContents);  //创建文本节点

    doc.appendChild(rootElement);   //创建跟节点

    rootElement.appendChild(childElement);  //创建子节点

    childElement.appendChild(textNode);   //创建文本值

    rootElement.setAttribute(name,value);  //创建元素属性

    带命名空间的文档:

    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

    factory.setNamespaceAware(true);

    builder = factory.newDocumentBuilder();

    String namespace = "http://www.w3.org/2000/svg";

    Element rootElement = doc.createElementNS(namespace,"svg"); //创建文档元素

    Element svgElement = doc.createElement(namespace,"svg:svg");  //带命名空间前缀的写法

    rootElement.setAttributeNS(namespace,qualifiedName,value);

     ----------------------------------------------------------------

    XML DOM输出
    方式1

    Transformer t = TransformerFactory.newInstance().newTransformer();   //这玩意干嘛的?从源到结果的转换API

    t.setOutputProperty(OutputKeys.DOCTYPE_SYSTEM,systemIdentifier);

    t.setOutputProperty(Outputkeys.DOCTYPE_SYSTEM,publicIdentifier);

    t.setOutputProperty(OutputKeys.INDENT,"yes");

    t.setOutputProperty(OutputKeys.METHOD,"xml");

    t.setOutputProperty("{http://xml.apache.org/xslt}indent-amount","2");

    t.transform(new DOMSource(doc),new StreamResult(new FileOutputStream(file)));  //执行上面的设置并且输出到文件中

    方式2 LSSerializer

    DOMImplementation impl = doc.getImplementation();

    DOMImplementationLS implLS = (DOMImplementationLS) impl.getFeature("LS","3.0");

    LSSerializer ser = implLS.createLSSerializer();

    ser.getDomConfig().setParameter("format-pretty-print",true);  //设置空格和换行

    String str = ser.writeToString(doc);  //将文档转换为字符串

    LSOutput out = implLS.createLSOutput();  

    out.setEncoding("UTF-8");

    out.setByteStream(Files.newOutputStream(path));

    ser.write(doc,out);  //将输出写入文件中

     方式3 StAX

    XMLOutputFactory factory = XMLOutputFactory.newInstance();

    XMLStreamWriter writer = factory.createXMLStreamWriter(out);

    接着是一系列的按XML顺序从上到下的操作,如:

    产生XML文件头  writer.writeStartDocument();

    添加子节点  writer.writeStartElement(name);

    ...

  • 相关阅读:
    django之orm单表查询
    python通过os.system()方法执行pscp提示却找不到该应用程序
    VUE 条件编译
    博客园Silence新主题美化,2021年最新更新!换个口味~
    JavaScript中数组的操作方法总汇
    Vue 上传材料(使用input)
    postgresql关于array类型有交集(包含查询数据任意元素,有重叠&&)的一些查询方法以及sqlalchemy语句实现
    linux便捷日志查询操作
    安装RabbitMQ
    v-model语法糖在input上组件上的使用
  • 原文地址:https://www.cnblogs.com/runwulingsheng/p/5439491.html
Copyright © 2020-2023  润新知