精彩的人生

          好好工作,好好生活

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            147 Posts :: 0 Stories :: 250 Comments :: 0 Trackbacks
          kXML is a small XML pull parser, specially designed for constrained environments such as Applets, Personal Java or MIDP devices.

          最小的版本只有11k,比那些龐大的xml解析起確實(shí)小好多。當(dāng)你對xml解析不需要很嚴(yán)格時(shí)可以使用它。

          下面是使用kxml的一段示例代碼:
          import org.xmlpull.v1.*;
          
          import java.util.*;
          import java.io.*;
          import java.net.*;
          
          /** 
           * A simple example illustrationg some differences of the XmlPull API 
           * and SAX. For the corresponding SAX based implementation, please refer to 
           * http://www.cafeconleche.org/slides/sd2001east/xmlandjava/81.html ff. */publicclassWeblogs {
          
              static List listChannels()
                  throws IOException, XmlPullParserException {
                  return listChannels("http://static.userland.com/weblogMonitor/logs.xml");
              }
          
              static List listChannels(String uri)
                  throws IOException, XmlPullParserException {
          
                  Vector result = new Vector();
          
                  InputStream is = new URL(uri).openStream();
                  XmlPullParser parser =
                      XmlPullParserFactory.newInstance().newPullParser();
          
                  parser.setInput(is, null);
          
                  parser.nextTag();
                  parser.require(XmlPullParser.START_TAG, "", "weblogs");
          
                  while (parser.nextTag() == XmlPullParser.START_TAG) {
                      String url = readSingle(parser);
                      if (url != null)
                          result.addElement(url);
                  }
                  parser.require(XmlPullParser.END_TAG, "", "weblogs");
          
                  parser.next();
                  parser.require(XmlPullParser.END_DOCUMENT, null, null);
          
          		is.close ();
          		parser.setInput (null);
          
                  return result;
              }
          
              publicstatic String readSingle(XmlPullParser parser)
                  throws IOException, XmlPullParserException {
          
                  String url = null;
                  parser.require(XmlPullParser.START_TAG, "", "log");
          
                  while (parser.nextTag() == XmlPullParser.START_TAG) {
                      String name = parser.getName();
                      String content = parser.nextText();
                      if (name.equals("url"))
                          url = content;
                      parser.require(XmlPullParser.END_TAG, "", name);
                  }
                  parser.require(XmlPullParser.END_TAG, "", "log");
                  return url;
              }
          
              publicstaticvoid main(String[] args)
                  throws IOException, XmlPullParserException {
          
                  List urls =
                      args.length > 0
                          ? listChannels(args[0])
                          : listChannels();
          
                  for (Iterator i = urls.iterator(); i.hasNext();)
                      System.out.println(i.next());
              }
          }
          



          摘自http://www.21tx.com/dev/2004/11/27/11901.html
          posted on 2006-04-03 10:34 hopeshared 閱讀(690) 評(píng)論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 剑河县| 遵义县| 同仁县| 栖霞市| 贵南县| 宁河县| 若尔盖县| 浦县| 白银市| 顺平县| 南靖县| 即墨市| 民权县| 随州市| 潮州市| 贵溪市| 东丰县| 海伦市| 徐州市| 宁蒗| 清涧县| 荆门市| 神池县| 屯门区| 梓潼县| 松江区| 盈江县| 调兵山市| 睢宁县| 龙川县| 额济纳旗| 镇康县| 鹤岗市| 横峰县| 翁源县| 迭部县| 克拉玛依市| 万安县| 万年县| 齐河县| 德庆县|