PULL解析XML文件

 //XML文件 
</strong></span>-<oschina>
   <catalog>0</catalog>
   <newsCount>0</newsCount>
   <pagesize>20</pagesize>
  -<newslist>
    -<news>
     <id>74612</id>
     <title> <![CDATA[Qampp 2.5.6 正式发布,集成 Subversion]]> </title>
     <body><![CDATA[更新日志: 1: 新集成Subversion 1.9.4, 协作开发SVN工具. 2: Apache 的配...]]></body>
     <commentCount>3</commentCount>
     <author><![CDATA[Tuesday]]></author>
     <authorid>998019</authorid>
     <pubDate>2016-06-24 09:47:04</pubDate>
     <url/>
  -<newstype>
     <type>0</type>
     <authoruid2>998019</authoruid2>
     <eventurl/>
   </newstype>
     
    </news>
   </newslist>
</oschina>
-------------------------------------------------------------
 public class MainActivity extends Activity {
    private String path = "http://www.oschina.net/action/api/news_list";
    List<Root> root_list;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
         // 开启子线程联网请求数据 
        new Thread() {
            public void run() {
                getdata();// 获取数据 
            }
        }.start();
    };              

//获取数据方法

private void getdata(){

try {

   URL url = new URL(path); //加载路径
            HttpURLConnection huc = (HttpURLConnection) url.openConnection(); // 获得连接网络的UI对象
            huc.setConnectTimeout(5000); // 设置请求超时
            huc.setReadTimeout(5000); // 设置读超时
            huc.setRequestMethod("GET"); //请求方式
            huc.connect(); // 获得连接网络

            if (huc.getResponseCode() == 200) {
                System.out.println("连接成功");
                InputStream inputStream = huc.getInputStream(); // 获得输入流
                XmlPullParser parser = Xml.newPullParser();
                parser.setInput(inputStream, "UTF-8");
                int eventType = parser.getEventType();

                 Root root = null;//封装类
                List<Root> root_list = null;//数据存入的集合
                while (eventType != XmlPullParser.END_DOCUMENT) {
                    switch (eventType) {
                    case XmlPullParser.START_DOCUMENT: // 文档开始事件,可以进行数据初始化处理
                        root_list = new ArrayList<Root>();//实例化集合
                        break;
                    case XmlPullParser.START_TAG:// 开始元素事件
                        String item = parser.getName();
                        if (item.equalsIgnoreCase( "news")) { //news开始
                             root = new Root();//实例化类
                        } else if ( root != null) { //判断类不为空

                            if (item.equals(" id")) { //与id比较
                                 root.setId(parser.nextText()); // 如果后面是Text元素,即返回它的值
                            } else if (item.equalsIgnoreCase("title")) {
                                root.setTitle(parser.nextText());
                            } else if (item.equalsIgnoreCase("body")) {
                                root.setBody(parser.nextText());
                            } else if (item.equalsIgnoreCase("commentCount")) {
                                root.setCommentCount(parser.nextText());
                            } else if (item.equalsIgnoreCase("author")) {
                                root.setAuthor(parser.nextText());
                            } else if (item.equalsIgnoreCase("authorid")) {
                                root.setAuthorid(parser.nextText());
                            } else if (item.equalsIgnoreCase("pubDate")) {
                                root.setPubDate(parser.nextText());
                            } else if (item.equalsIgnoreCase("url")) {
                                root.setUrl(parser.nextText());
                            }
                        }
                        break;
                    case XmlPullParser.END_TAG:// 结束元素事件
                        if (parser.getName().equalsIgnoreCase(" news") //news结束
                                && root != null) { //类不为空
                            root_list.add(root); //把数据存入集合
                            root = null; //设置类为空
                        }
                        break;
                    }
                    eventType = parser.next();
                }
   //测试遍历集合
                for (Root root2 : root_list) {
                    System.out.println(root2.toString());
                }



//handler发送到主线程
                Message msg = Message.obtain();
                msg.obj = root_list;
                msg.what = 1;
                handler.sendMessage(msg);



            }
        } catch (MalformedURLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }// 获urlUI对象
        catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (XmlPullParserException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    };


    

    }
}



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值