• Pull解析xml


    没有写抛出的异常,例子是含有多个Person对象persons.xml(此片内容未写写入的代码),包含id,name,email,address标签,Person对象含有id,name,email,address属性。

    1、获取pull解析工具类以及说明要解析的文件

      XmlPullParser parser = Xml.newPullParser();

      File path=new File(Environment.getExternalStorageDirectory(),"要解析的xml文件名字");

      FileInputStream in = new FileInputStream(path);

      parser.setInput(in, "utf-8");//设置你要解析那个文件,已什么编码格式把它读入到内存

    2、解析 

      int eventType = parser.getEventType();

      List<Person> list = null;

      Person p = null;

      while(eventType != parser.END_DOCUMENT){

        switch (eventType) {

         case XmlPullParser.START_TAG: //访问静态变量的时候用类名来访问,不要用对象去调用

          if("persons".equals(parser.getName())){

            list = new ArrayList<Person>();

          }else if("person".equals(parser.getName())) //当遇到了person节点的时候创建person对象并解析id属性给person对象

          {

            p=new Person();

            int id = Integer.parseInt(parser.getAttributeValue(null, "id"));

             p.setId(id);

          }else if("name".equals(parser.getName())){

             String name = parser.nextText(); //一般用nextText 不用getText
             p.setName(name);
           }else if("email".equals(parser.getName())){
             String email = parser.nextText(); //一般用nextText 不用getText
             p.setEmail(email);
           }else if("address".equals(parser.getName())){
             String address = parser.nextText(); //一般用nextText 不用getText
             p.setAddress(address);
           }
           break;
         case XmlPullParser.END_TAG:
            if("person".equals(parser.getName()))//表示person结束了,将person对象加入到list中

            {
              list.add(p);
              p = null; //及时的让我们不用的对象成为垃圾
            }
           break;

       }
        eventType = parser.next(); //尤其容易忘记
     }

    //打印一下解析出来的所有对象
      for(Person person : list){
         Log.d(TAG, person.toString());//一般情况TAG表示定义常量,值为当前类名
      }

  • 相关阅读:
    【转载】八大排序算法
    【转载】算法的时间复杂度和空间复杂度的计算
    【转载】SpringMVC前台给后台传值的方式
    Session方法
    配置《算法 第四版》的Eclipse开发环境
    Learning Scrapy笔记(三)- Scrapy基础
    Learning Scrapy笔记(七)- Scrapy根据Excel文件运行多个爬虫
    Learning Scrapy笔记(六)- Scrapy处理JSON API和AJAX页面
    Scrapy Learning笔记(四)- Scrapy双向爬取
    Learning Scrapy笔记(五)- Scrapy登录网站
  • 原文地址:https://www.cnblogs.com/zzw1994/p/4892722.html
Copyright © 2020-2023  润新知