亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android 使用Pull方法解析XML文件的方法

2020-04-11 12:21:53
字體:
來源:轉載
供稿:網友
Pull解析方法給應用程序完全的控制文檔該怎么樣被解析。Android中對Pull方法提供了支持的API,主要是
復制代碼 代碼如下:

org.xmlpull.v1.XmlPullParser;
org.xmlpull.v1.XmlPullParserFactory;

二個類,其中主要使用的是XmlPullParser,XmlPullParserFactory是一個工廠,用于構建XmlPullParser對象。
應用程序通過調用XmlPullParser.next()等方法來產生Event,然后再處理Event??梢钥吹剿cPush方法的不同,Push方法是由Parser自己主動產生Event,回調給應用程序。而Pull方法是主動的調用Parser的方法才能產生事件。
假如XML中的語句是這樣的:"<author country="United States">James Elliott</author>",author是TAG,country是ATTRIBUTE,"James Elliott"是TEXT。
要想解析文檔先要構建一個XmlPullParser對象
復制代碼 代碼如下:

final XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
factory.setNamespaceAware(true);
final XmlPullParser parser = factory.newPullParser();

Pull解析是一個遍歷文檔的過程,每次調用next(),nextTag(), nextToken()和nextText()都會向前推進文檔,并使Parser停留在某些事件上面,但是不能倒退。
然后把文檔設置給Parser
復制代碼 代碼如下:

parser.setInput(new StringReader("<author country=/"United States/">James Elliott</author>");

這時,文檔剛被初始化,所以它應該位于文檔的開始,事件應該是START_DOCUMENT,可以通過XmlPullParser.getEventType()來獲取。然后調用next()會產生
START_TAG,這個事件告訴應用程序一個標簽已經開始了,調用getName()會返回"author";再next()會產生
TEXT事件,調用getText()會返回"James Elliott",再next(),會產生
END_TAG,這個告訴你一個標簽已經處理完了,再next(),會產生
END_DOCUMENT,它告訴你整個文檔已經處理完成了。
除了next()外,nextToken()也可以使用,只不過它會返回更加詳細的事件,比如 COMMENT, CDSECT, DOCDECL, ENTITY等等非常詳細的信息。如果程序得到比較底層的信息,可以用nextToken()來驅動并處理詳細的事件。需要注意一點的是TEXT事件是有可能返回空白的White Spaces比如換行符或空格等。
另外有二個非常實用的方法nextTag()和nextText()
nextTag()--首先它會忽略White Spaces,如果可以確定下一個是START_TAG或END_TAG,就可以調用nextTag()直接跳過去。通常它有二個用處:當START_TAG時,如果能確定這個TAG含有子TAG,那么就可以調用nextTag()產生子標簽的START_TAG事件;當END_TAG時,如果確定不是文檔結尾,就可以調用nextTag()產生下一個標簽的START_TAG。在這二種情況下如果用next()會有TEXT事件,但返回的是換行符或空白符。
nextText()--它只能在START_TAG時調用。當下一個元素是TEXT時,TEXT的內容會返回;當下一個元素是END_TAG時,也就是說這個標簽的內容為空,那么空字串返回;這個方法返回后,Parser會停在END_TAG上。比如:
復制代碼 代碼如下:

<author>James Elliott</author>
<author></author>
<author/>

當START_TAG時,調用nextText(),依次返回:
"James Elliott"
""(empty)
""(empty)
這個方法在處理沒有子標簽的標簽時很有用。比如:
復制代碼 代碼如下:

<title>What Is Hibernate</title>
<author>James Elliott</author>
<category>Web</category>

就可以用以下代碼來處理:
復制代碼 代碼如下:

        while (eventType != XmlPullParser.END_TAG) {
            switch (eventType) {
            case XmlPullParser.START_TAG:
                tag = parser.getName();
                final String content = parser.nextText();
                Log.e(TAG, tag + ": [" + content + "]");
                eventType = parser.nextTag();
                break;
            default:
                break;
            }
        }

這就要比用next()來處理方便多了,可讀性也大大的加強了。
最后附上一個解析XML的實例Android程序
復制代碼 代碼如下:

import java.io.IOException;
import java.io.InputStream;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory;
import android.util.Log;
public class RssPullParser extends RssParser {
    private final String TAG = FeedSettings.GLOBAL_TAG;

    private InputStream mInputStream;

    public RssPullParser(InputStream is) {
        mInputStream = is;
    }

    public void parse() throws ReaderBaseException, XmlPullParserException, IOException {
        if (mInputStream == null) {
            throw new ReaderBaseException("no input source, did you initialize this class correctly?");
        }
        final XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
        factory.setNamespaceAware(true);
        final XmlPullParser parser = factory.newPullParser();

        parser.setInput(mInputStream);
        int eventType = parser.getEventType();
        if (eventType != XmlPullParser.START_DOCUMENT) {
            throw new ReaderBaseException("Not starting with 'start_document'");
        }
        eventType = parseRss(parser);
        if (eventType != XmlPullParser.END_DOCUMENT) {
            throw new ReaderBaseException("not ending with 'end_document', do you finish parsing?");
        }
        if (mInputStream != null) {
            mInputStream.close();
        } else {
            Log.e(TAG, "inputstream is null, XmlPullParser closed it??");
        }
    }

    /**
     * Parsing the Xml document. Current type must be Start_Document.
     * After calling this, Parser is positioned at END_DOCUMENT.
     * @param parser
     * @return event end_document
     * @throws XmlPullParserException
     * @throws ReaderBaseException
     * @throws IOException
     */
    private int parseRss(XmlPullParser parser) throws XmlPullParserException, ReaderBaseException, IOException {
        int eventType = parser.getEventType();
        if (eventType != XmlPullParser.START_DOCUMENT) {
            throw new ReaderBaseException("not starting with 'start_document', is this a new document?");
        }
        Log.e(TAG, "starting document, are you aware of that!");
        eventType = parser.next();
        while (eventType != XmlPullParser.END_DOCUMENT) {
            switch (eventType) {
            case XmlPullParser.START_TAG: {
                Log.e(TAG, "start tag: '" + parser.getName() + "'");
                final String tagName = parser.getName();
                if (tagName.equals(RssFeed.TAG_RSS)) {
                    Log.e(TAG, "starting an RSS feed <<");
                    final int attrSize = parser.getAttributeCount();
                    for (int i = 0; i < attrSize; i++) {
                        Log.e(TAG, "attr '" + parser.getAttributeName(i) + "=" + parser.getAttributeValue(i) + "'");
                    }
                } else if (tagName.equals(RssFeed.TAG_CHANNEL)) {
                    Log.e(TAG, "/tstarting an Channel <<");
                    parseChannel(parser);
                }
                break;
            }
            case XmlPullParser.END_TAG: {
                Log.e(TAG, "end tag: '" + parser.getName() + "'");
                final String tagName = parser.getName();
                if (tagName.equals(RssFeed.TAG_RSS)) {
                    Log.e(TAG, ">> edning an RSS feed");
                } else if (tagName.equals(RssFeed.TAG_CHANNEL)) {
                    Log.e(TAG, "/t>> ending an Channel");    
                }
                break;
            }
            default:
                break;
            }
            eventType = parser.next();
        }
        Log.e(TAG, "end of document, it is over");
        return parser.getEventType();
    }

    /**
     * Parse a channel. MUST be start tag of an channel, otherwise exception thrown.
     * Param XmlPullParser
     * After calling this function, parser is positioned at END_TAG of Channel.
     * return end tag of a channel
     * @throws XmlPullParserException
     * @throws ReaderBaseException
     * @throws IOException
     */
    private int parseChannel(XmlPullParser parser) throws XmlPullParserException, ReaderBaseException, IOException {
        int eventType = parser.getEventType();
        String tagName = parser.getName();
        if (eventType != XmlPullParser.START_TAG || !RssFeed.TAG_CHANNEL.equals(tagName)) {
            throw new ReaderBaseException("not start with 'start tag', is this a start of a channel?");
        }
        Log.e(TAG, "/tstarting " + tagName);
        eventType = parser.nextTag();
        while (eventType != XmlPullParser.END_TAG) {
            switch (eventType) {
            case XmlPullParser.START_TAG: {
                final String tag = parser.getName();
                if (tag.equals(RssFeed.TAG_IMAGE)) {
                    parseImage(parser);
                } else if (tag.equals(RssFeed.TAG_ITEM)) {
                    parseItem(parser);
                } else {
                    final String content = parser.nextText();
                    Log.e(TAG, tag + ": [" + content + "]");
                }
                // now it SHOULD be at END_TAG, ensure it
                if (parser.getEventType() != XmlPullParser.END_TAG) {
                    throw new ReaderBaseException("not ending with 'end tag', did you finish parsing sub item?");
                }
                eventType = parser.nextTag();
                break;
            }
            default:
                break;
            }
        }
        Log.e(TAG, "/tending " + parser.getName());
        return parser.getEventType();
    }

    /**
     * Parse image in a channel.
     * Precondition: position must be at START_TAG and tag MUST be 'image'
     * Postcondition: position is END_TAG of '/image'
     * @throws IOException
     * @throws XmlPullParserException
     * @throws ReaderBaseException
     */
    private int parseImage(XmlPullParser parser) throws XmlPullParserException, IOException, ReaderBaseException {
        int eventType = parser.getEventType();
        String tag = parser.getName();
        if (eventType != XmlPullParser.START_TAG || !RssFeed.TAG_IMAGE.equals(tag)) {
            throw new ReaderBaseException("not start with 'start tag', is this a start of an image?");
        }
        Log.e(TAG, "/t/tstarting image " + tag);
        eventType = parser.nextTag();
        while (eventType != XmlPullParser.END_TAG) {
            switch (eventType) {
            case XmlPullParser.START_TAG:
                tag = parser.getName();
                Log.e(TAG, tag + ": [" + parser.nextText() + "]");
                // now it SHOULD be at END_TAG, ensure it
                if (parser.getEventType() != XmlPullParser.END_TAG) {
                    throw new ReaderBaseException("not ending with 'end tag', did you finish parsing sub item?");
                }
                eventType = parser.nextTag();
                break;
            default:
                break;
            }
        }
        Log.e(TAG, "/t/tending image " + parser.getName());
        return parser.getEventType();
    }

    /**
     * Parse an item in a channel.
     * Precondition: position must be at START_TAG and tag MUST be 'item'
     * Postcondition: position is END_TAG of '/item'
     * @throws IOException
     * @throws XmlPullParserException
     * @throws ReaderBaseException
     */
    private int parseItem(XmlPullParser parser) throws XmlPullParserException, IOException, ReaderBaseException {
        int eventType = parser.getEventType();
        String tag = parser.getName();
        if (eventType != XmlPullParser.START_TAG || !RssFeed.TAG_ITEM.equals(tag)) {
            throw new ReaderBaseException("not start with 'start tag', is this a start of an item?");
        }
        Log.e(TAG, "/t/tstarting " + tag);
        eventType = parser.nextTag();
        while (eventType != XmlPullParser.END_TAG) {
            switch (eventType) {
            case XmlPullParser.START_TAG:
                tag = parser.getName();
                final String content = parser.nextText();
                Log.e(TAG, tag + ": [" + content + "]");
                // now it SHOULD be at END_TAG, ensure it
                if (parser.getEventType() != XmlPullParser.END_TAG) {
                    throw new ReaderBaseException("not ending with 'end tag', did you finish parsing sub item?");
                }
                eventType = parser.nextTag();
                break;
            default:
                break;
            }
        }
        Log.e(TAG, "/t/tending " + parser.getName());
        return parser.getEventType();
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品日韩电影| 精品美女永久免费视频| 一区二区三区视频在线| 国产欧美婷婷中文| 日韩av电影免费观看高清| 国产一区视频在线播放| 在线看国产精品| 国产精品久久久久久久久久新婚| 国内精品久久久久影院优| 国产精品十八以下禁看| 国产精品视频一区二区高潮| 九九久久综合网站| 国产噜噜噜噜噜久久久久久久久| 成人精品一区二区三区电影黑人| 国产又爽又黄的激情精品视频| 日本不卡高字幕在线2019| 欧美肥老太性生活视频| 日韩性xxxx爱| 国产精品免费一区二区三区都可以| 中日韩美女免费视频网址在线观看| 国产亚洲一级高清| 欧洲精品在线视频| 久久久999精品| 91热福利电影| 日韩中文字幕国产| 亚洲精品欧美一区二区三区| 色777狠狠综合秋免鲁丝| 91精品久久久久久久久久久久久| 国产精品免费一区二区三区都可以| 亚洲天堂男人天堂| 亚洲va久久久噜噜噜久久天堂| 欧美制服第一页| 久久久久女教师免费一区| 久久视频这里只有精品| 欧美激情视频一区| 2021国产精品视频| 中文字幕国产亚洲2019| 精品久久在线播放| 久久亚洲精品国产亚洲老地址| 欧美极品欧美精品欧美视频| 国产精品国内视频| 亚洲日本中文字幕| 亚洲人成在线观看| 欧美激情国产精品| 久久久之久亚州精品露出| 亚洲欧美一区二区精品久久久| 日韩精品极品视频免费观看| 91丝袜美腿美女视频网站| 色噜噜国产精品视频一区二区| 91热精品视频| 亚洲美女福利视频网站| 国产精品一区二区在线| 日韩欧美国产免费播放| 欧美电影在线免费观看网站| 国语自产精品视频在线看一大j8| 欧美成人免费大片| 亚洲一区二区三区视频| 日韩免费电影在线观看| 国产亚洲精品美女| 欧美极品在线视频| 九九热最新视频//这里只有精品| 亚洲综合日韩中文字幕v在线| 国产精品高潮呻吟久久av野狼| 欧美一区在线直播| 久久久亚洲网站| 91视频国产高清| 午夜精品久久久久久久99热| 欧美老女人性生活| 亚洲欧洲在线视频| 国产精品影院在线观看| 欧美中文在线观看| 亚洲影院在线看| 亚洲精美色品网站| 亚洲欧美中文字幕| 午夜剧场成人观在线视频免费观看| 久久av资源网站| 精品动漫一区二区| 国产91在线播放九色快色| 茄子视频成人在线| 黑人精品xxx一区一二区| 欧美大片大片在线播放| 国产免费亚洲高清| 久久好看免费视频| 精品女同一区二区三区在线播放| 亚洲xxxx在线| 欧洲精品在线视频| 成人免费在线视频网址| 午夜精品国产精品大乳美女| 欧美性videos高清精品| 成人福利网站在线观看11| 俺去亚洲欧洲欧美日韩| 91精品国产91久久久| 亚洲欧洲激情在线| 国产精品美女久久久久av超清| 国产精品美女999| 国产91精品在线播放| 国产91九色视频| 欧美在线国产精品| 一区二区三区在线播放欧美| 欧美亚洲视频在线观看| 国产精品第二页| 日韩精品久久久久久福利| 免费97视频在线精品国自产拍| 久久精彩免费视频| 91精品久久久久久久久青青| 日韩综合视频在线观看| 国产精品成熟老女人| 日韩在线视频网| 狠狠躁天天躁日日躁欧美| 69视频在线免费观看| 国产综合在线看| 色婷婷成人综合| 日韩高清有码在线| 亚洲精品视频在线播放| 国产精品极品美女在线观看免费| 久久久久中文字幕| 精品中文视频在线| 国内精品小视频在线观看| 国产精品福利在线观看网址| 日韩av综合网站| 日韩中文字幕久久| 欧美日韩国产一中文字不卡| 亚洲免费av网址| 爱福利视频一区| 最近2019中文字幕第三页视频| 红桃av永久久久| 91国在线精品国内播放| 81精品国产乱码久久久久久| 最近中文字幕mv在线一区二区三区四区| 国产一区二区日韩精品欧美精品| 美女视频黄免费的亚洲男人天堂| 国产欧美一区二区三区久久人妖| 亚洲片国产一区一级在线观看| 欧美巨猛xxxx猛交黑人97人| 欧美性受xxx| 亚洲免费影视第一页| 国产精品美腿一区在线看| 91成人福利在线| 中文字幕久热精品视频在线| 国产欧美日韩专区发布| 欧美亚洲国产精品| 精品美女永久免费视频| 欧美激情三级免费| 中文字幕欧美国内| 日韩大陆毛片av| 久色乳综合思思在线视频| 久久精品国产久精国产一老狼| 国产一区二区成人| 国产精品91在线| 国模视频一区二区三区| 国产噜噜噜噜久久久久久久久| 欧美性xxxxx极品| 国产97在线观看| 欧美激情国产日韩精品一区18| 在线观看日韩av| 欧美性极品少妇精品网站| 久久久综合免费视频| 成人h片在线播放免费网站| 久久精品国产v日韩v亚洲| 91精品国产91久久久久久久久| 狠狠操狠狠色综合网| 5566日本婷婷色中文字幕97| 九九精品在线观看| 国产精品丝袜视频|