XML,即 extensible Markup Language
,是一种数据标记语言 & 传输格式
关于另外1种主流的数据传输格式
JSON
,具体请看:Carson带你学序列化:深入分析JSON多种解析方式(Gson、AS自带org.json、Jackson)
对数据进行标记(结构化数据)、存储 & 传输
区别于
html
:html
用于显示信息;而XML
用于存储&传输信息
< p >this is a bitch <p>
< P >这是错误的<p>
< p >这是正确的 <p>
<root><kid></kid>
</root>
<note date="16/08/08">
</note>
实体引用 | 符号 | 含义 |
---|---|---|
<; | < | 小于 |
> ; | > | 大于 |
&; | & | 和浩 |
&apos; | ‘ | 单引号 |
"; | " | 双引号 |
元素不能使用&(实体的开始)和<(新元素的开始)
注释
<!-- This is a comment -->
XML的元素、属性和属性值
文档实例
<bookstore><book category="CHILDREN"><title lang="en"> Harry Potter </title><author> JK.Rowling</author></book>
<book category="WEB"><title lang="en"> woshiPM </title><author>Carson_Ho</author></book>
</bookstore>
其中,是根元素;是子元素,也是元素类型之一;而中含有属性,即category,属性值是CHILDREN;而元素则拥有文本内容( JK.Rowling)
范例一
<bookstore><book category="CHILDREN"><title lang="en"> Harry Potter </title><author> JK.Rowling</author></book>
范例二
<bookstore><book ><category>CHILDREN<category><title lang="en"> Harry Potter </title><author> JK.Rowling</author></book>
范例一和二提供的信息是完全相同的。
一般情况下,请使用元素,因为
使用属性的情况:用于分配ID索引,用于标识XML元素。
实例
<bookstore><book id = "501"><category>CHILDREN<category><title lang="en"> Harry Potter </title><author> JK.Rowling</author></book><book id = "502"><category>CHILDREN<category><title lang="en"> Harry Potter </title><author> JK.Rowling</author></book>
<bookstore>
上述属性(id)仅用于标识不同的便签,并不是数据的组成部分
CDATA
不被解析器解析的文本数据,所有xml文档都会被解析器解析(cdata区段除外)
<![CDATA["传输的文本 "]]>
PCDATA
被解析的字符数据
XML文档中的元素会形成一种树结构,从根部开始,然后拓展到每个树叶(节点),下面将以实例说明XML的树结构。
<?xml version ="1.0" encoding="UTF-8"?>
<简历><基本资料><求职意向><自我评价><其他信息><联系方式><我的作品></简历>
其树结构如下
XML节点解释
XML文件是由节点构成的。它的第一个节点为“根节点”。一个XML文件必须有且只能有一个根节点,其他节点都必须是它的子节点。
this 代表整个XML文件,它的根节点就是 this.firstChild 。 this.firstChild.childNodes 则返回由根节点的所有子节点组成的节点数组。
每个子节点又可以有自己的子节点。节点编号由0开始,根节点的第一个子节点为 this.firstChild.childNodes[0],它的子节点数组就是this.firstChild.childNodes[0].childNodes 。
根节点第一个子节点的第二个子节点 this.firstChild.childNodes[0].childNodes[1],它返回的是一个XML对象(Object) 。这里需要特别注意,节点标签之间的数据本身也视为一个节点 this.firstChild.childNodes[0].childNodes[1].firstChild ,而不是一个值。
我们解析XML的最终目的当然就是获得数据的值:this.firstChild.childNodes[0].childNodes[1].deValue 。
请注意区分:节点名称(<性别></性别>)和之间的文本内容(男)可以当作是节点,也可以当作是一个值
节点:
名称:this.firstChild.childNodes[0].childNodes[1]
文本内容:this.firstChild.childNodes[0].childNodes[1].firstChild
值:
名称:this.firstChild.childNodes[0].childNodes[1].nodeValue
(节点名称有时也是我们需要的数据)
文本内容:this.firstChild.childNodes[0].childNodes[1].nodeName
在了解完XML之后,是时候来学下如何进行XML的解析了
XML
,即从XML
中提取有用的信息XML
的解析方式主要分为2大类:Document Object Model
,即 文件对象模型,是 一种 基于树形结构节点 & 文档驱动 的XML解析方法定义了访问 & 操作xml文档元素的方法和接口
// 假设需要解析的XML文档如下l)<?xml version ="1.0" encoding="UTF-8"?>`
<code>
<language id="1"><name>Java</name><usage>Android</usage></language>
<language id="2"><name>Swift#</name><usage>iOS</usage></language>
<language id="3"><name>Html5</name><usage>Web</usage></language></code>// 解析的核心代码public static List<subject> getSubjectList(InputStream stream){ tv = (TextView)findViewById(R.id.tv);try {//打开xml文件到输入流InputStream stream = getAssets().open(l");//得到 DocumentBuilderFactory 对象DocumentBuilderFactory builderFactory = wInstance();//得到DocumentBuilder对象DocumentBuilder builder = wDocumentBuilder();//建立Document存放整个xml的Document对象数据Document document = builder.parse(stream);//得到 XML数据的"根节点" Element element = DocumentElement();//获取根节点的所有language的节点NodeList list = ElementsByTagName("language");//遍历所有节点for (int i= 0;i<Length();i++){//获取lan的所有子元素Element language = (Element) list.item(i);//获取language的属性(这里即为id)并显示tv.Attribute("id")+"n");//获取language的子元素 name 并显示 tv.ElementsByTagName("name").item(0).getTextContent()+"n");//获取language的子元素usage 并显示 tv.ElementsByTagName("usage").item(0).getTextContent()+"n");}
简介
即 Simple API for XML
,一种 基于事件流驱动、通过接口方法解析 的XML解析方法
解析原理
解析实例
在使用SAX
解析XML
文档时,关键在于 自定义自己的Handler
处理类 & 复写对应方法
public class MyHandler extends DefaultHandler{ @Override public void startDocument() throws SAXException{ } @Override public void startElement(String uri,String localName,String qName, Attributes attributes) throws SAXException{ } @Override public void characters(char[] ch,int start,int length) throws SAXException{ } @Override public void endElement(String uri,String localName,String qName) throws SAXException{ } @Override public void endDocument() throws SAXException{ }
}
简介
一种 基于事件流驱动 的XML
解析方法
解析原理
注:
Android
中自带了Pull
解析的jar
包,故不需额外导入第三方jar
包
// Pull使用循环解析
XmlPullParserFactory factory = wInstance();
XmlPullParser xmlPullParser = wPullParser();
xml.setInput(new StringReader(xmlData)); int eventType = EventType(); while(eventType!=XmlPullParser.END_DOCUMENT){ String nodeName = Name(); switch(eventType){ case XmlPullParser.START_DOCUMENT:{} case XmlPullParser.START_TAG:{} case XmlPullParser.END_TAG:{} } eventType = ();
}
public class MainActivity extends Activity {private EditText et;private Button myButton;@Overridepublic void onCreate(Bundle savedInstanceState) {Create(savedInstanceState);setContentView(R.layout.activity_main);myButton = (Button) this.findViewById(R.id.btn01);et = (EditText) this.findViewById(R.id.edittext01);myButton.setOnClickListener(new OnClickListener() {//可变字符序列,比StringBuffer块StringBuilder sb = new StringBuilder("");Resources res = getResources();XmlResourceParser xrp = l.subject);@Overridepublic void onClick(View v) {int counter = 0;try {// 判断是否到了文件的结尾while (EventType() != XmlPullParser.END_DOCUMENT) {//文件的内容的起始标签开始,这里的起始标签是l文件里面<subjects>标签下面的第一个标签int eventTypeEventType();switch (eventType) {case XmlPullParser.START_DOCUMENT:break;case XmlPullParser.START_TAG:String tagname = Name();if (dsWith("language")) {counter++;sb.append("这是第" + counter + "种语言"+"n");//可以调用XmlPullParser的getAttributte()方法来获取属性的值sb.append("语言id是:"AttributeValue(0)+"n");}else if(tagname.equals("name")){//可以调用XmlPullParser的nextText()方法来获取节点的值sb.append("语言名称是:"Text()+"n");}else if(tagname.equals("teacher")){sb.append("用途是:"Text()+"n");}break;case XmlPullParser.END_TAG:break;case XmlPullParser.TEXT:break;}//解析下一个事件();}//StringBuilder要调用toString()方法并显示et.String());} catch (XmlPullParserException e) {} catch (IOException e) {e.printStackTrace();}}});}
XML
,下面用一张图总结XML
的主流解析方法JSON
,具体请看:Carson带你学序列化:深入分析JSON多种解析方式(Gson、AS自带org.json、Jackson)博客链接:/
本文发布于:2024-02-03 08:21:25,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170691968349810.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |