pull解析器解析xml

    利用pull解析XML文件需要下面几个步骤:

     1)获取XMLPullParser对象。这里有两个方法:通过XMLPullParserFactory获取XMLPullParser对象,或者直接使用Xml.newPullParser()方法获取。栗子如代码一所示。

     2)通过XMLPullParser对象设置输入流。

     3)通过parser.next(),持续的解析XML文件直到文件的尾部。

下面的几个方法是经常需要的:XMLPullParserFacotry.newInstance( )    facotry.newPullParser( )  Xml.newPullParser() parser.setInput( )     parser.next( ).


注意:
1)parser.next()方法使指向下移一个最小元素。
举个栗子:
<title>静夜思</title>
这这里首先指向<title>,调用parser.next()后,会指向 静夜思 ,再调用parser.next(),指向</title>。
2)我无论使用现有的xml文件还是用xml字符串作为数据源,parser.nextText()方法皆不好使,会报XmlPullParserException。暂不知原因。
3)使用xml文件做数据源时,使用parser.next()会报nullpointexception。不知道原因,猜测是格式有误。
4)解析xml时,有以下方式:
方式一,判断标签类型。下面是栗子。
 while (eventType != XmlPullParser.END_DOCUMENT) {
                if (eventType == XmlPullParser.START_DOCUMENT) {
                    Log.d("tag", "StartDocument3--" + parser.getName());
                }
                if (eventType == XmlPullParser.START_TAG) {
                    Log.d("tag", "StartTag--" + parser.getName());
                }
                if (eventType == XmlPullParser.TEXT) {
                    Log.d("tag", "Text--" + parser.getText());
                }
                if (eventType == XmlPullParser.END_TAG) {
                    Log.d("tag", "EndTag--" + parser.getName());
                }

方式二,判断标签name,下面是栗子。
           while (eventType != XmlPullParser.END_DOCUMENT) {
                Log.i("xml", "WhileBegin--");
                if ("poem".equals(parser.getName())) {
                    Log.i("xml", "poem--" + parser.getName());
                } else if ("title".equals(parser.getName())) {
                    Log.i("xml", "title--" + parser.getName());
                } else if ("author".equals(parser.getName())) {
                    Log.i("xml", "author--" + parser.getName());
                } else if ("content".equals(parser.getName())) {
                    Log.i("xml", "content--" + parser.getName());
                }

方式三,两者混合,本人比较推荐。
 while (type != XmlPullParser.END_DOCUMENT) {
            switch (type) {
            case XmlPullParser.START_TAG:
                Log.i("WeatherService", "StartTag");
                if ("infos".equals(parser.getName())) {
                    weatherInfos = new ArrayList<WeatherInfo>();
                } else if ("city".equals(parser.getName())) {
                    weatherInfo = new WeatherInfo();
                    String idStr = parser.getAttributeValue(0);
                    weatherInfo.setId(Integer.parseInt(idStr));
                } else if ("name".equals(parser.getName())) {
                    type = parser.next();
                    String name = parser.getText();
                    weatherInfo.setName(name);
                }
            case XmlPullParser.TEXT:
                Log.i("WeatherService", "XmlText");    
                break;
            case XmlPullParser.START_DOCUMENT:
                Log.i("WeatherService", "StartDoc");
                break;
            case XmlPullParser.END_TAG:
                Log.i("WeatherService", "EndTag");
                if ("city".equals(parser.getName())) {
                    weatherInfos.add(weatherInfo);
                    weatherInfo = null;
                }
                break;
            }


代码如下:
代码一:使用字符串作为数据源
public class MainActivity extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        try {
            XmlPullParserFactory factory;// 1.第一步,创建解析工厂
            factory = XmlPullParserFactory.newInstance();
            factory.setNamespaceAware(true);  // 设置支持命名空间
            XmlPullParser parser = factory.newPullParser();// 2.生成parser对象
            // 3.设置输入
            parser.setInput(new StringReader(
                    "<?xml version=\"1.0\" ?><poem><title>静夜思</title><author>李白</author><content>床前明月光,疑似地上霜,举头忘明月,低头思故乡</content></poem>"));
            int eventType = parser.getEventType();// 获取输入类型
            while (eventType != XmlPullParser.END_DOCUMENT) {
                if (eventType == XmlPullParser.START_DOCUMENT) {
                    Log.d("tag", "StartDocument3--" + parser.getName());
                }
                if (eventType == XmlPullParser.START_TAG) {
                    Log.d("tag", "StartTag--" + parser.getName());
                }
                if (eventType == XmlPullParser.TEXT) {
                    Log.d("tag", "Text--" + parser.getText());
                }
                if (eventType == XmlPullParser.END_TAG) {
                    Log.d("tag", "EndTag--" + parser.getName());
                }
                eventType = parser.next(); // 不断的去更新
            }
        } catch (XmlPullParserException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        try {
            XmlPullParser parser = Xml.newPullParser();  // 1.生成parser对象
            // 2.设置输入
            parser.setInput(new StringReader(
                    "<?xml version=\"1.0\" ?><poem><title>静夜思</title><author>李白</author><content>床前明月光,疑似地上霜,举头忘明月,低头思故乡</content></poem>"));
            int eventType = parser.getEventType();// 获取输入类型
            while (eventType != XmlPullParser.END_DOCUMENT) {
                Log.i("xml", "WhileBegin--");
                if ("null".equals((String) parser.getName())) {
                    Log.i("xml", "null--" + parser.getName());
                } else if ("poem".equals(parser.getName())) {
                    Log.i("xml", "poem--" + parser.getName());
                    //这里使用getNext()方法会造成XmlPullParserException错误,原因不知
                    //Log.i("xml", "poemNextText--" + parser.nextText());
                } else if ("title".equals(parser.getName())) {
                    Log.i("xml", "title--" + parser.getName());
                } else if ("author".equals(parser.getName())) {
                    Log.i("xml", "author--" + parser.getName());
                } else if ("content".equals(parser.getName())) {
                    Log.i("xml", "content--" + parser.getName());
                }
                eventType = parser.next(); // 不断的去更新
            }
        } catch (XmlPullParserException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}


代码二:
public class WeatherService {
    public static List<WeatherInfo> getWeatherInfos(InputStream iStream)
            throws Exception {
        XmlPullParser parser = Xml.newPullParser();
        parser.setInput(new StringReader(
                "<?xml version=\"1.0\" encoding=\"utf-8\"?><infos><city id=\"1\" ><name>上海</name><weather>多云</weather><temp>20℃/30℃</temp><pm>80</pm><wind>1级 </wind></city><city id=\"2\" ><name>北京</name><weather>晴天</weather><temp>26℃/32℃</temp><pm>120</pm><wind>2级</wind></city><city id=\"3\" ><name>吉林</name><weather>小雨</weather><temp>14℃/25℃</temp><pm>60</pm><wind>2级</wind></city></infos>"));

        List<WeatherInfo> weatherInfos = null;
        WeatherInfo weatherInfo = null;
        int type = parser.getEventType();
        Log.i("parserType",String.valueOf(type));
        Log.i("parserEndDoc",String.valueOf(XmlPullParser.END_DOCUMENT));
        while (type != XmlPullParser.END_DOCUMENT) {
            Log.i("WeatherService", "while");
            switch (type) {
            case XmlPullParser.START_TAG:
                Log.i("WeatherService", "StartTag");
                if ("infos".equals(parser.getName())) {
                    weatherInfos = new ArrayList<WeatherInfo>();
                } else if ("city".equals(parser.getName())) {
                    weatherInfo = new WeatherInfo();
                    String idStr = parser.getAttributeValue(0);
                    weatherInfo.setId(Integer.parseInt(idStr));
                } else if ("name".equals(parser.getName())) {
                    type = parser.next();
                    String name = parser.getText();
                    weatherInfo.setName(name);
                } else if ("weather".equals(parser.getName())) {
                    type = parser.next();
                    String weather = parser.getText();
                    weatherInfo.setWeather(weather);
                } else if ("temp".equals(parser.getName())) {
                    type = parser.next();
                    String temp = parser.getText();
                    weatherInfo.setTemp(temp);
                } else if ("pm".equals(parser.getName())) {
                    type = parser.next();
                    String pm = parser.getText();
                    weatherInfo.setPm(pm);
                } else if ("wind".equals(parser.getName())) {
                    type = parser.next();
                    String wind = parser.getText();
                    weatherInfo.setWind(wind);
                }
            case XmlPullParser.TEXT:
                Log.i("WeatherService", "XmlText");    
                break;
            case XmlPullParser.START_DOCUMENT:
                Log.i("WeatherService", "StartDoc");
                break;
            case XmlPullParser.END_TAG:
                Log.i("WeatherService", "EndTag");
                if ("city".equals(parser.getName())) {
                    weatherInfos.add(weatherInfo);
                    weatherInfo = null;
                }
                break;
            }
            type = parser.next();
        }
        iStream.close();
        return weatherInfos;
    }
}



参考页面

利用 TensorFlow 训练自己的目标识别器。本文内容来自于我的毕业设计,基于 TensorFlow 1.15.0,其他 TensorFlow 版本运行可能存在问题。.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值