从网站解析XML在Android的一个String数组,请帮帮我(Parsing XML from

2019-10-16 18:44发布

你好,我是在做一个Android应用程序,就会从一个Wiki的一些数据,起初我打算寻找一种方法来解析HTML的过程,但是从事情,有人向我指出的是,XML将更加容易一起工作。 现在,我是卡试图找到一种方法来正确地解析XML。 我想,现在从网络地址解析:

http://zelda.wikia.com/api.php?action=query&list=categorymembers&cmtitle=Category:Games&cmlimit=500&format=xml

我试图让每一个游戏的标题为一个字符串数组,我遇到了一些麻烦。 我没有代码,我尝试的一个例子,它是通过使用xmlpullparser。 我的应用程序崩溃每次我试图用它做任何事情。 它会更好保存到本地XML,并从那里解析? 或者我会好起来的,从网址去? 我怎么会去正确地分析此为一个字符串数组? 请帮我,感谢您抽出宝贵的时间来阅读。

如果您需要查看的代码或任何东西,我可以得到它后,今晚,我只是不靠近我的电脑在这个时候。 谢谢。

Answer 1:

当你发现自己编写解析器代码进行简单的格式,像在你的例子你总是做错了什么,而不是使用一个合适的框架。

例如-有在解析XML一套简单的助手android.sax包SDK中包含的,它只是碰巧你张贴的例子可以很容易地分析如下:

public class WikiParser {
    public static class Cm {
        public String mPageId;
        public String mNs;
        public String mTitle;
    }
    private static class CmListener implements StartElementListener {
        final List<Cm> mCms;
        CmListener(List<Cm> cms) {
            mCms = cms;
        }
        @Override
        public void start(Attributes attributes) {
            Cm cm = new Cm();
            cm.mPageId = attributes.getValue("", "pageid");
            cm.mNs = attributes.getValue("", "ns");
            cm.mTitle = attributes.getValue("", "title");
            mCms.add(cm);
        }
    }
    public void parseInto(URL url, List<Cm> cms) throws IOException, SAXException {
        HttpURLConnection con = (HttpURLConnection) url.openConnection();
        try {
            parseInto(new BufferedInputStream(con.getInputStream()), cms);
        } finally {
            con.disconnect();
        }
    }
    public void parseInto(InputStream docStream, List<Cm> cms) throws IOException, SAXException {
        RootElement api = new RootElement("api");
        Element query = api.requireChild("query");
        Element categoryMembers = query.requireChild("categorymembers");
        Element cm = categoryMembers.requireChild("cm");
        cm.setStartElementListener(new CmListener(cms));
        Xml.parse(docStream, Encoding.UTF_8, api.getContentHandler());
    }
}

基本上,像这样调用:

WikiParser p = new WikiParser();
ArrayList<WikiParser.Cm> res = new ArrayList<WikiParser.Cm>();
try {
    p.parseInto(new URL("http://zelda.wikia.com/api.php?action=query&list=categorymembers&cmtitle=Category:Games&cmlimit=500&format=xml"), res);
} catch (MalformedURLException e) {
} catch (IOException e) {
} catch (SAXException e) {}

编辑:这是你如何创建一个List<String>代替:

public class WikiParser {
    private static class CmListener implements StartElementListener {
        final List<String> mTitles;
        CmListener(List<String> titles) {
            mTitles = titles;
        }
        @Override
        public void start(Attributes attributes) {
            String title = attributes.getValue("", "title");
            if (!TextUtils.isEmpty(title)) {
                mTitles.add(title);
            }
        }
    }
    public void parseInto(URL url, List<String> titles) throws IOException, SAXException {
        HttpURLConnection con = (HttpURLConnection) url.openConnection();
        try {
            parseInto(new BufferedInputStream(con.getInputStream()), titles);
        } finally {
            con.disconnect();
        }
    }
    public void parseInto(InputStream docStream, List<String> titles) throws IOException, SAXException {
        RootElement api = new RootElement("api");
        Element query = api.requireChild("query");
        Element categoryMembers = query.requireChild("categorymembers");
        Element cm = categoryMembers.requireChild("cm");
        cm.setStartElementListener(new CmListener(titles));
        Xml.parse(docStream, Encoding.UTF_8, api.getContentHandler());
    }
}

接着:

WikiParser p = new WikiParser();
ArrayList<String> titles = new ArrayList<String>();
try {
    p.parseInto(new URL("http://zelda.wikia.com/api.php?action=query&list=categorymembers&cmtitle=Category:Games&cmlimit=500&format=xml"), titles);
} catch (MalformedURLException e) {
} catch (IOException e) {
} catch (SAXException e) {}


文章来源: Parsing XML from a website to a String array in Android please help me