为了方便的将spritesheet的图导入我自己的动画编辑器!
我做了plist文件解析
DOM解析比较麻烦 因为element getChildNodes 会获取到text对象。而这个对象可能是一个空白字符解析起来异常麻烦!
 
 DOM 采用建立树形结构的方式访问 XML 文档,而 SAX 采用的事件模型。

  DOM 解析器把 XML 文档转化为一个包含其内容的树,并可以对树进行遍历。用 DOM 解析模型的优点是编程容易,开发人员只需要调用建树的指令,然后利用navigation APIs访问所需的树节点来完成任务。可以很容易的添加和修改树中的元素。然而由于使用 DOM 解析器的时候需要处理整个 XML 文档,所以对性能和内存的要求比较高,尤其是遇到很大的 XML 文件的时候。由于它的遍历能力,DOM 解析器常用于 XML 文档需要频繁的改变的服务中。

  SAX 解析器采用了基于事件的模型,它在解析 XML 文档的时候可以触发一系列的事件,当发现给定的tag的时候,它可以激活一个回调方法,告诉该方法制定的标签已经找到。SAX 对内存的要求通常会比较低,因为它让开发人员自己来决定所要处理的tag。特别是当开发人员只需要处理文档中所包含的部分数据时,SAX 这种扩展能力得到了更好的体现。但用 SAX 解析器的时候编码工作会比较困难,而且很难同时访问同一个文档中的多处不同数据。 
 
DOM [树型结构] SAX [事件驱动型]
于是采用SAX解析!网上有人写过,但存在些问题,于是自己做了修改测试!放出代码如下:

  1. package logame.core;
  2. import java.util.ArrayList;
  3. import java.util.HashMap;
  4. import java.util.LinkedList;
  5. import java.util.List;
  6. import java.util.Map;
  7. import java.util.Stack;
  8. import org.xml.sax.Attributes;
  9. import org.xml.sax.SAXException;
  10. import org.xml.sax.helpers.DefaultHandler;
  11. /**
  12. * .plist配置文件的解析器
  13. *
  14. * @author afly
  15. *
  16. */
  17. public class PlistHandler extends DefaultHandler {
  18. private boolean isRootElement = false;
  19. private boolean keyElementBegin = false;
  20. private String key;
  21. Stack<Object> stack = new Stack<Object>();
  22. private boolean valueElementBegin = false;
  23. private Object root;
  24. @SuppressWarnings("unchecked")
  25. public HashMap<String, Object> getMapResult() {
  26. return (HashMap<String, Object>) root;
  27. }
  28. @SuppressWarnings("unchecked")
  29. public List<Object> getArrayResult() {
  30. return (List<Object>) root;
  31. }
  32. @Override
  33. public void startDocument() throws SAXException {
  34. System.out.println("开始解析");
  35. }
  36. @Override
  37. public void endDocument() throws SAXException {
  38. System.out.println("结束解析");
  39. }
  40. @SuppressWarnings("unchecked")
  41. @Override
  42. public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
  43. // System.out.println(uri+"startElement:"+qName);
  44. if ("plist".equals(qName)) {
  45. isRootElement = true;
  46. }
  47. if ("dict".equals(qName)) {
  48. if (isRootElement) {
  49. stack.push(new HashMap<String, Object>());// 压栈
  50. isRootElement = !isRootElement;
  51. } else {
  52. Object object = stack.peek();
  53. HashMap<String, Object> dict = new HashMap<String, Object>();
  54. if (object instanceof ArrayList)
  55. ((ArrayList<Object>) object).add(dict);
  56. else if (object instanceof HashMap)
  57. ((HashMap<String, Object>) object).put(key, dict);
  58. stack.push(dict);
  59. }
  60. }
  61. if ("key".equals(qName)) {
  62. keyElementBegin = true;
  63. }
  64. if ("true".equals(qName)) {
  65. HashMap<String, Object> parent = (HashMap<String, Object>) stack.peek();
  66. parent.put(key, true);
  67. }
  68. if ("false".equals(qName)) {
  69. HashMap<String, Object> parent = (HashMap<String, Object>) stack.peek();
  70. parent.put(key, false);
  71. }
  72. if ("array".equals(qName)) {
  73. if (isRootElement) {
  74. ArrayList<Object> obj = new ArrayList<Object>();
  75. stack.push(obj);
  76. isRootElement = !isRootElement;
  77. } else {
  78. HashMap<String, Object> parent = (HashMap<String, Object>) stack.peek();
  79. ArrayList<Object> obj = new ArrayList<Object>();
  80. stack.push(obj);
  81. parent.put(key, obj);
  82. }
  83. }
  84. if ("string".equals(qName)) {
  85. valueElementBegin = true;
  86. }
  87. }
  88. /*
  89. * 字符串解析(non-Javadoc)
  90. *
  91. * @see org.xml.sax.helpers.DefaultHandler#characters(char[], int, int)
  92. */
  93. @SuppressWarnings("unchecked")
  94. @Override
  95. public void characters(char[] ch, int start, int length) throws SAXException {
  96. System.out.println("characters:");
  97. if (length > 0) {
  98. if (keyElementBegin) {
  99. key = new String(ch, start, length);
  100. System.out.println("key:" + key);
  101. }
  102. if (valueElementBegin) {
  103. if (HashMap.class.equals(stack.peek().getClass())) {
  104. HashMap<String, Object> parent = (HashMap<String, Object>) stack.peek();
  105. String value = new String(ch, start, length);
  106. parent.put(key, value);
  107. } else if (ArrayList.class.equals(stack.peek().getClass())) {
  108. ArrayList<Object> parent = (ArrayList<Object>) stack.peek();
  109. String value = new String(ch, start, length);
  110. parent.add(value);
  111. }
  112. System.out.println("value:" + new String(ch, start, length));
  113. }
  114. }
  115. }
  116. @Override
  117. public void endElement(String uri, String localName, String qName) throws SAXException {
  118. if ("plist".equals(qName)) {
  119. ;
  120. }
  121. if ("key".equals(qName)) {
  122. keyElementBegin = false;
  123. }
  124. if ("string".equals(qName)) {
  125. valueElementBegin = false;
  126. }
  127. if ("array".equals(qName)) {
  128. root = stack.pop();
  129. }
  130. if ("dict".equals(qName)) {
  131. root = stack.pop();
  132. }
  133. }
  134. }

调用也相对比较简单:

  1. SAXParserFactory factorys = SAXParserFactory.newInstance();
  2. SAXParser saxparser = factorys.newSAXParser();
  3. PlistHandler plistHandler = new PlistHandler();
  4. saxparser.parse(uri, plistHandler);
  5. HashMap<String, Object> hash = plistHandler.getMapResult();
  6. ArrayList<Object> array =  (ArrayList<Object>)plistHandler.getArrayResult();

返回可以是一个  dict 也可以是一个array根据自己的格式获得。

【转】java 解析 plist文件的更多相关文章

  1. java解析xml文件并输出

    使用java解析xml文件,通过dom4j,代码运行前需先导入dom4j架包. ParseXml类代码如下: import java.io.File; import java.util.ArrayLi ...

  2. 使用Java解析XML文件或XML字符串的例子

    转: 使用Java解析XML文件或XML字符串的例子 2017年09月16日 11:36:18 inter_peng 阅读数:4561 标签: JavaXML-Parserdom4j 更多 个人分类: ...

  3. [Xcode 实际操作]七、文件与数据-(8 )读取和解析Plist文件(属性列表文件)

    目录:[Swift]Xcode实际操作 本文将演示如何读取和解析Plist文件,即属性列表文件. 它是用来存储,串行化后的对象的文件. 在项目名称上点击鼠标右键,弹出右键菜单, 选择[New File ...

  4. Java解析JSON文件的方法

    http://blog.sina.com.cn/s/blog_628cc2b70101dydc.html java读取文件的方法 http://www.cnblogs.com/lovebread/ar ...

  5. Java解析xml文件遇到特殊符号&会出现异常的解决方案

    文/朱季谦 在一次Java解析xml文件的开发过程中,使用SAX解析时,出现了这样一个异常信息: Error on line 60 of document : 对实体 "xxx" ...

  6. java解析XML文件

    dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的.dom4j是一个非常非常优秀的Java XML API,具有性能优异.功能强大和极端易用使用的特点,同时它也是一个开放源 ...

  7. java解析properties文件

    在自动化测试过程中,经常会有一些公用的属性要配置,以便后面给脚本使用,我们可以选择xml, excel或者json格式来存贮这些数据,但其实java本身就提供了properties类来处理proper ...

  8. ios开发学习- 简易音乐播放器2 (基于iPhone4s屏幕尺寸)-- 歌词解析--plist文件应用--imageNamed图片加载耗内存

    声明:(部分图片来自网络,如果侵犯了您的权益请联系我,会尽快删除!) 又是音乐播放器,不过这次和上次不一样了,准确说这次更像播放器了,初学者不建议看这个,可以先看前面一个音乐播放器(1),当然 我没加 ...

  9. JAVA解析XML文件(DOM,SAX,JDOM,DOM4j附代码实现)

    1.解析XML主要有四种方式 1.DOM方式解析XML(与平台无关,JAVA提供,一次性加载XML文件内容,形成树结构,不适用于大文件) 2.SAX方式解析XML(基于事件驱动,逐条解析,适用于只处理 ...

随机推荐

  1. 详解 CSS 属性 - 伪类和伪元素的区别[转]

    首先,阅读 w3c 对两者的定义: CSS 伪类用于向某些选择器添加特殊的效果. CSS 伪元素用于将特殊的效果添加到某些选择器. 可以明确两点,第一两者都与选择器相关,第二就是添加一些“特殊”的效果 ...

  2. 在使用MOS管时要注意的问题

    1.当Vds电压增大,Ciss增大,栅极充放电电流也会增大 2.MOS管的功率损耗要控制在额定功耗以下 3.在Buck电路中,开关MOS管的Vds在MOS管关断时会非常大

  3. HDU 1532 Drainage Ditches 最大流 (Edmonds_Karp)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1532 感觉题意不清楚,不知道是不是个人英语水平问题.本来还以为需要维护入度和出度来找源点和汇点呢,看 ...

  4. 哈希,哈希表,哈希Map

    数组: 数组存储区间是连续的,占用内存严重,故空间复杂的很大.但数组的二分查找时间复杂度小,为O(1):数组的特点是:寻址容易,插入和删除困难: 链表: 链表存储区间离散,占用内存比较宽松,故空间复杂 ...

  5. ABAP打开TCODE

    CALL FUNCTION 'TH_CREATE_MODE'  EXPORTING    transaktion    = 'ZGNBWD001'  EXCEPTIONS    max_session ...

  6. 李洪强iOS开发Swift篇—05_元组类型

    李洪强iOS开发Swift篇—05_元组类型 一.元组类型介绍 1.什么是元组类型 元组类型由 N个 任意类型的数据组成(N >= 0),组成元组类型的数据可以称为“元素” 示例: let po ...

  7. OA学习笔记-007-Dao层设计

    一. User, UserDao save(User user), update(), delete(), find(), ...Role, RoleDao save(Role role), upda ...

  8. ANDROID_MARS学习笔记_S02_013_Gson解析json串

    1.MainActivity.java package com.json; import java.io.IOException; import java.io.StringReader; impor ...

  9. Qt创建窗体的过程

    版权声明 本文为原创作品,请尊重作者的劳动成果.转载必须保持文章完整性,并以超链接形式注明原始作者“ tingsking18”和 主站点地址,方便其他朋友提问和指正. QT源码解析(一) QT创建窗口 ...

  10. webview调用javascript脚本无反应

    最近遇到一个问题:在html中有一段javascript脚本定义了一个方法,在使用webview.loadUrl("javascript:方法名()")时方法未执行,后来 查资料发 ...