zoukankan      html  css  js  c++  java
  • pull 解析XML 文件

    pull解析的特点

    • 事件驱动机制来解析
    • 当解析到一个节点,会自动停止,不会往下继续解析,好处 :很好能够控制流程
    • android默认采用pull解析

     

    pull解析的事件类型

    • start_document :开始文档事件 ,事件类型
    • end_docuent :结束文档事件
    • start_tag: 开始标记
    • end_tag :结束标记
        private List<Map<String, String>> getXmlFormPull(InputStream is)
                throws Exception {
            List<Map<String, String>> mList = null;
            Map<String, String> map = null;
            // 1 得到pull对象
            XmlPullParser xml = Xml.newPullParser();
            xml.setInput(is, "utf-8");
            // 2 得到标记
            int eventType = xml.getEventType();
            // 判断标记 是否结束, 因为 pull 当解析到一个节点,会自动停止,不会往下继续解析
            while (eventType != XmlPullParser.END_DOCUMENT) {
                // 判断当前的节点信息
                switch (eventType) {
                case XmlPullParser.START_DOCUMENT:
                    // xml文件的开始,初始化一个list
                    mList = new ArrayList<Map<String, String>>();
                    break;
                case XmlPullParser.START_TAG:
                    // START_TAG ,有多个,需要进行判断
                    String TagName = xml.getName();
                    if (TagName.equals("books")) {
                        // 根节点 ,创建mapduixiang
                      
                    } else if (TagName.equals("book")) {
                map = new HashMap<String, String>();
    // 第一属性节点 String id = xml.getAttributeValue(0); map.put("ID", id); } else if (TagName.equals("name")) { String name = xml.nextText(); map.put("name", name); } else if (TagName.equals("price")) { String price = xml.nextText(); map.put("price", price); } break; case XmlPullParser.END_TAG: // 结束节点,一个子节点完成 if (xml.getName().equals("book")) { mList.add(map); } break; default: break; } // 标记移动到下一个节点 eventType = xml.next(); } System.out.println(mList.toString()); return mList; }
    大道至简,知易行难,知行合一,得到功成;大道至简,悟在天成。
  • 相关阅读:
    合肥禹州珑玥湾业主qq群:791026131
    Operation category READ is not supported in state standby 故障解决
    yarn资源调度之FairScheduler
    storm启动和拓扑启动和关闭的一般命令
    es的一些实用案例
    leetCode例题引出的多线程CountDownLatch和CyclicBarrier使用例题
    spark运维管理
    spark streaming基础
    spark sql工作原理、性能优化和spark on hive----转载
    spark-sql基础
  • 原文地址:https://www.cnblogs.com/XingzhiDai/p/5557496.html
Copyright © 2011-2022 走看看