アンドロイドはXmlPullParserを使用してXMLファイルを解析します
次の XML を解析します:
<?xml version="1.0" encoding="utf-8" ?> <rss><sid>77f265bb46de068e78f35afbadec62af</sid><count>3</count><control>0</control> <mblog><uid>1195224593</uid><favid>3436952795</favid><mblogid>5xtaJR</mblogid><mblogidnum>3436952795</mblogidnum> <mblogtype>0</mblogtype><mlevel>0</mlevel><feedid>5xtaJR</feedid><nick>马艳丽</nick> <portrait> <vip>1</vip> <vipsubtype>0</vipsubtype> <member_type>13</member_type> <remark></remark> <level>2</level> <rtnum>11</rtnum> <commentnum>25</commentnum> <attitudenum>0</attitudenum> <attitudeid>0</attitudeid> <attitudes_status>0</attitudes_status> <attitudes_count>0</attitudes_count> <mblogtypename></mblogtypename> <visible><type>0</type><list_id>0</list_id></visible> <content>婚礼在北海美丽的北海公园举行…好美好浪漫的地方… </content> <pic> <source>彩信</source> </mblog> </rss>
次のように解析を記述します:
public static Object[] getMBlogList(String content) throws HttpException { try { Object[] result = new Object[3]; List<MBlog> lst = new ArrayList<MBlog>(); result[1] = lst; final XmlPullParser parser = Xml.newPullParser(); parser.setInput(new StringReader(content)); int type; while ((type = parser.next()) != XmlPullParser.END_DOCUMENT) { switch (type) { <strong>case XmlPullParser.START_TAG:这里开始读取最外层的标签属性</strong> if (parser.getName().equals("count")) { try { result[0] = new Integer(parseText(parser)); } catch (Exception e) { result[0] = 0; } } else if (parser.getName().equals("mblog")) { MBlog mb = parseMBlog(parser); if (mb != null) lst.add(mb); } else if (parser.getName().equals("relation")) { result[2] = new Integer(parseText(parser)); } break; default: break; } } return result; } catch (NumberFormatException e) { throw new HttpException(e); } catch (XmlPullParserException e) { throw new HttpException(e); } catch (IOException e) { throw new HttpException(e); } catch (ParseException e) { throw new HttpException(e); } } private static String parseText(XmlPullParser parser) throws ParseException { try { int type = parser.next(); if (type == XmlPullParser.TEXT) { return replaceEntityRef(parser.getText().trim()); } else { return ""; } } catch (Exception e) { throw new ParseException(PARSE_ERROR, e); } } public static MBlog parseMBlog(XmlPullParser parser) throws ParseException { <strong>MBlog b = new MBlog();//这里开始读取每个MBlog对象</strong> try { int type; LOOP: { while ((type = parser.next()) != XmlPullParser.END_DOCUMENT) { switch (type) { case XmlPullParser.START_TAG: if (parser.getName().equals("uid")) { b.uid = parseText(parser); if (b.uid.equals("")) return null; } else if (parser.getName().equals("favid")) { b.favid = parseText(parser); } else if (parser.getName().equals("mblogid")) { b.mblogid = parseText(parser); } else if (parser.getName().equals("nick")) { String s = parseText(parser); b.nick = s; } else if (parser.getName().equals("portrait")) { b.portrait = parseText(parser); } else if (parser.getName().equals("vip")) { b.vip = (parseText(parser).equals("1")) ? true : false; } else if (parser.getName().equals("content")) { b.content = parseText(parser); } else if (parser.getName().equals("rtrootuid")) { b.rtrootuid = parseText(parser); } else if (parser.getName().equals("rtrootid")) { b.rtrootid = parseText(parser); } else if (parser.getName().equals("rtrootnick")) { String s = parseText(parser); b.rtrootnick = s; } else if (parser.getName().equals("rtrootvip")) { b.rtrootvip = (parseText(parser).equals("1")) ? true : false; } else if (parser.getName().equals("rtreason")) { b.rtreason = parseText(parser); } else if (parser.getName().equals("rtnum")) { b.rtnum = Integer.parseInt(parseText(parser)); } else if (parser.getName().equals("commentnum")) { b.commentnum = Integer.parseInt(parseText(parser)); } else if (parser.getName().equals("time")) { b.time = new Date(Long.parseLong(parseText(parser)) * 1000); } else if (parser.getName().equals("pic")) { b.pic = parseText(parser); } else if (parser.getName().equals("source")) { b.src = parseText(parser); } else if (parser.getName().equals("longitude")) { b.longitude = parseText(parser); } else if (parser.getName().equals("latitude")) { b.latitude = parseText(parser); } break; case XmlPullParser.END_TAG: if (parser.getName().equals("mblog")) { break LOOP; } break; default: break; } } } return b; } catch (Exception e) { throw new ParseException(PARSE_ERROR, e); } }
アクティビティで次のように呼び出します:
上記はAndroidがXmlPullParserを使用する方法ですXML ファイルの内容を解析します。その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









ここ数日、Ice Universeは、サムスンの次期主力スマートフォンであると広く信じられているGalaxy S25 Ultraの詳細を着実に明らかにしている。とりわけ、リーカーはサムスンがカメラのアップグレードを1つだけ計画していると主張した

OnLeaks は、X (旧 Twitter) のフォロワーから 4,000 ドル以上を集めようとして失敗した数日後、Android Headlines と提携して Galaxy S25 Ultra のファーストルックを提供しました。コンテキストとして、h の下に埋め込まれたレンダリング イメージ

TCLは、2つの新しいスマートフォンの発表に加えて、NXTPAPER 14と呼ばれる新しいAndroidタブレットも発表しました。その巨大な画面サイズはセールスポイントの1つです。 NXTPAPER 14 は、TCL の代表的なブランドであるマット LCD パネルのバージョン 3.0 を搭載しています。

ここ数日、Ice Universeは、サムスンの次期主力スマートフォンであると広く信じられているGalaxy S25 Ultraの詳細を着実に明らかにしている。とりわけ、リーカーはサムスンがカメラのアップグレードを1つだけ計画していると主張した

Vivo Y300 Pro は完全に公開されたばかりで、大容量バッテリーを備えた最もスリムなミッドレンジ Android スマートフォンの 1 つです。正確に言うと、このスマートフォンの厚さはわずか 7.69 mm ですが、6,500 mAh のバッテリーを搭載しています。これは最近発売されたものと同じ容量です

サムスンは、ファンエディション(FE)スマートフォンシリーズをいつアップデートするかについて、まだ何のヒントも提供していない。現時点では、Galaxy S23 FE は 2023 年 10 月初めに発表された同社の最新版のままです。

Redmi Note 14 Pro Plusは、昨年のRedmi Note 13 Pro Plus(Amazonで現在375ドル)の直接の後継者として正式に発表されました。予想通り、Redmi Note 14 Pro Plusは、Redmi Note 14およびRedmi Note 14 Proと並んでRedmi Note 14シリーズをリードします。李

Motorola は今年数え切れないほどのデバイスをリリースしましたが、そのうち折りたたみ式デバイスは 2 つだけです。ちなみに、世界の大部分ではこのペアが Razr 50 および Razr 50 Ultra として受け入れられていますが、Motorola は北米では Razr 2024 および Razr 2 として提供しています。
