XML文件和SAXParser解析器
阿新 • • 發佈:2018-12-22
比較簡單的就不記錄了。記一些容易忘的。
XML部分
1、特殊字元如何表示為純文字
這些字元在xml中屬於特殊字元,它代表的不是本身字元的意思。因此特殊字元表示成純文字,就要通過特殊的辦法來表示
方法一:實體引用
方法二:CDATA標記
<![CDATA[文字內容]]>
注意,實體引用放入這裡,也會變成純文字
2、註釋規則
3、什麼是DTD或者Schema約束
約束了在哪些根標籤下會出現哪些子標籤,形成一種規範,這樣在解析xml的時候,就有了規範。
JAXP解析xml文件部分
解析的原理:
一行一行的掃描下來,當遇到標籤開始時,就傳送一個標籤開始事件訊號,當遇到標籤結束時,就傳送一個標籤結束訊號。我們在事件監聽器中就能獲得當前標籤的資訊了。
java程式碼:
Code: 在SAXPrase.class 中解析bean1.xml
public class SAXParse { public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException { SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser parse = factory.newSAXParser();// 得到SAXPraser物件 parse.parse("src\\bean1.xml", new MyHandler());// 傳入路徑,監聽器 } }
Code: 在MyHandler.class 監聽事件
public class MyHandler extends DefaultHandler { private String currentTag; // 每當處理文字資料時,觸發該方法 @Override public void characters(char[] ch, int start, int length) throws SAXException { String content = new String(ch, start, length); // 當元素間的文件存在時,列印 if (content.trim().length() > 0) { System.out.println("<"+currentTag+">元素的值是:"+content.trim()); } } //解析文件結束時觸發該方法 @Override public void endDocument() throws SAXException { System.out.println("解析文件結束"); } //解析元素結束時觸發該方法 @Override public void endElement(String uri, String localName, String qName) throws SAXException { System.out.println("處理元素結束:"+qName); } //每當解析文件開始時觸發該方法 @Override public void startDocument() throws SAXException { System.out.println("解析文件開始"); } @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { System.out.println("開始處理元素:"+qName); currentTag=qName; if (attributes.getLength()>0) { System.out.println("<"+currentTag+">元素的屬性如下:"); for (int i = 0; i < attributes.getLength(); i++) { System.out.println(attributes.getQName(i)+"--->"+attributes.getValue(i)); } } } }
至此,就得到了XML文件的各個內容,再通過自己的需求,取出其中的資料即可
生成XML文件部分:
public class BuildXMLMain {
public static void main(String[] args) throws Exception {
//建立儲存XML的結果流物件
Result resultXML=new StreamResult(new File("D://firstxml1.xml"));
//獲取sax生成工廠例項
SAXTransformerFactory saxTransformerFactory=(SAXTransformerFactory) SAXTransformerFactory.newInstance();
//獲取SAX生成處理者物件例項
TransformerHandler transformerHandler=saxTransformerFactory.newTransformerHandler();
transformerHandler.setResult(resultXML);
//獲取SAX生成器
Transformer transformer=transformerHandler.getTransformer();
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
//生成文件的開始
transformerHandler.startDocument();
AttributesImpl attrImpl=new AttributesImpl();
transformerHandler.startElement("", "", "書籍列表", attrImpl);
transformerHandler.startElement("", "", "計算機書籍", attrImpl);
transformerHandler.startElement("", "", "書名", attrImpl);
transformerHandler.characters("Java思想".toCharArray(), 0, "Java思想".length());
transformerHandler.endElement("", "", "書名");
transformerHandler.startElement("", "", "作者", attrImpl);
transformerHandler.characters("小王".toCharArray(), 0, "小王".length());
transformerHandler.endElement("", "", "作者");
transformerHandler.startElement("", "", "價格", attrImpl);
transformerHandler.characters("79.00".toCharArray(), 0, "79.00".length());
transformerHandler.endElement("", "", "價格");
transformerHandler.endElement("", "", "計算機書籍");
//第二本書
transformerHandler.startElement("", "", "計算機書籍", attrImpl);
transformerHandler.startElement("", "", "書名", attrImpl);
transformerHandler.characters("Spring指南".toCharArray(), 0, "Spring指南".length());
transformerHandler.endElement("", "", "書名");
transformerHandler.startElement("", "", "作者", attrImpl);
transformerHandler.characters("小李".toCharArray(), 0, "小李".length());
transformerHandler.endElement("", "", "作者");
transformerHandler.startElement("", "", "價格", attrImpl);
transformerHandler.characters("89.00".toCharArray(), 0, "89.00".length());
transformerHandler.endElement("", "", "價格");
transformerHandler.endElement("", "", "計算機書籍");
transformerHandler.endElement("", "", "書籍列表");
//告訴handler文件生成已結束
transformerHandler.endDocument();
System.out.println("XML文件生成成功!");
}
}