国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

xml中的dtd約束的加深了解以及dom的解析方式和jaxp解析xml文檔 ——Web部分第七天

2019-11-14 12:57:56
字體:
來源:轉載
供稿:網友

xml中的dtd約束的加深了解以及dom的解析方式和jaxp解析xml文檔 ——Web部分第七天

dtd約束的加深

* 語法<!ATTLIST 元素名稱 屬性名稱 屬性類型 屬性的約束>* 屬性類型包括: - CDATA : 字符串 - 枚舉 : 如(aa|bb|cc)只能出現其中一個 - ID : 值只能是字母或者下劃線開頭<!ATTLIST name ID3 CDATA #REQUIRED><!ATTLIST name ID3 (aa|bb|cc) #REQUIRED><!ATTLIST name ID3 ID #REQUIRED>* 屬性的約束 - #REQUIRED : 屬性必須存在 - #IMPLIED : 屬性可有可無 - FIXED : 表示一個固定值如#FIXED "aaa" , 屬性必須設置這個固定值 ; - 直接值 : 不寫屬性,使用直接值, 寫了屬性,就用那個值。(相當于默認值)* 定義實體 - 語法<!ENTITY 實體名稱 "實體內容"> - 引用時 &實體名稱;(注:包括分號)。

- 定義實體要寫在內部dtd里面,否則某些瀏覽器解析不到。

xml的解析方式

* xml的解析方式dom和sax(同html相同),三家公司提供了dom解析器 - jaxp(java相關) , dom4j(實際開發) , jdom 。

jaxp解析xml文檔

* 包 javax.xml.perser , javax.xml.transform , org.w3c.dom ;* 下為dom的解析方式,添加刪除的原理和js相同,個別方法名不同。package com.xml.test;import java.io.IOException;import java.security.acl.Permission;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import javax.xml.parsers.ParserConfigurationException;import javax.xml.transform.Transformer;import javax.xml.transform.TransformerFactory;import javax.xml.transform.dom.DOMSource;import javax.xml.transform.stream.StreamResult;import org.w3c.dom.Document;import org.w3c.dom.Element;import org.w3c.dom.Node;import org.w3c.dom.NodeList;import org.w3c.dom.Text;import org.xml.sax.SAXException;public class xmlTest { public static void main(String [] args) throws Exception{ //test01(); //test02(); //test03() ; //test04() ; //test05() ; test06() ; } /* * 遞歸遍歷所有節點 */ PRivate static void test06() throws Exception { Document document = DocumentBuilderFactory.newInstance().newDocumentBuilder() .parse("src/person.xml") ; Node node = document.getElementsByTagName("person").item(0) ; listAll(node) ; } private static void listAll(Node node) { if (node.getNodeType() == Node.ELEMENT_NODE ) { System.out.println(node.getNodeName()) ; } NodeList nodeList = node.getChildNodes() ; for(int i = 0 ; i < nodeList.getLength() ; i++ ){ Node nodeText = nodeList.item(i) ; if (nodeText.getNodeType() == Node.TEXT_NODE) { System.out.println(nodeText.getTextContent()); } listAll(nodeText) ; } } /* * 刪除節點sex */ private static void test05() throws Exception { Document document = DocumentBuilderFactory.newInstance().newDocumentBuilder() .parse("src/person.xml") ; Node node = document.getElementsByTagName("p1").item(0) ; Node node2 = document.getElementsByTagName("sex").item(0) ; node.removeChild(node2) ; Transformer transformer = TransformerFactory.newInstance().newTransformer() ; transformer.transform(new DOMSource(document) , new StreamResult("src/person.xml")) ; } /* * 修改xml標簽下的內容 * 在p1的標簽下修改<sex>nv</sex> nv為nan */ private static void test04() throws Exception { Document document = DocumentBuilderFactory.newInstance().newDocumentBuilder() .parse("src/person.xml") ; Node node = document.getElementsByTagName("sex").item(0) ; node.setTextContent("nan") ; Transformer transformer = TransformerFactory.newInstance().newTransformer() ; transformer.transform(new DOMSource(document) , new StreamResult("src/person.xml")); } /* * 在p1的標簽下添加<sex>nv</sex> * * 重點: 添加完成后的回寫動作。 * * java的操作是在內存中完成的,并沒有回寫到文件。 */ private static void test03() throws Exception { Document document = DocumentBuilderFactory.newInstance() .newDocumentBuilder().parse("src/person.xml") ; Element sex = document.createElement("sex") ; Text sexText = document.createTextNode("nv") ; sex.appendChild(sexText) ; NodeList nodeList = document.getElementsByTagName("p1") ; nodeList.item(0).appendChild(sex) ; //回寫操作 Transformer transform = TransformerFactory.newInstance().newTransformer() ; transform.transform(new DOMSource(document) , new StreamResult("src/person.xml")) ; } /* * 查詢某一個節點。 */ private static void test02() throws Exception { DocumentBuilder documentBuilder = DocumentBuilderFactory .newInstance().newDocumentBuilder() ; Document document = documentBuilder.parse("src/Person.xml") ; NodeList nodeList = document.getElementsByTagName("name") ; Node node = nodeList.item(0) ; System.out.println(node.getTextContent()) ; } /* * 遍歷xml */ private static void test01() throws Exception { //創建解析器工廠實例 DocumentBuilderFactory dbd = DocumentBuilderFactory.newInstance() ; //通過解析器工廠實例得到解析器 DocumentBuilder db = dbd.newDocumentBuilder() ; //通過解析器解析文檔,得到Document對象 Document document = db.parse("src/person.xml") ; //得到標簽節點 NodeList nodeList = document.getElementsByTagName("name") ; for(int i = 0 ; i < nodeList.getLength() ; i++ ){ //得到Node里面的值 Node node = nodeList.item(i) ; String str = node.getTextContent() ; System.out.println(str); } }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 泰州市| 秀山| 罗源县| 万州区| 通城县| 陆河县| 确山县| 河池市| 新蔡县| 福贡县| 中宁县| 阳朔县| 彰武县| 揭东县| 黄陵县| 东至县| 昌平区| 衡南县| 瓮安县| 镇安县| 洛隆县| 神池县| 城市| 曲阳县| 芷江| 铁岭市| 简阳市| 德江县| 三门县| 镇宁| 洞口县| 唐海县| 大安市| 石渠县| 景泰县| 株洲县| 永川市| 双牌县| 远安县| 犍为县| 安岳县|