精彩的人生

          好好工作,好好生活

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            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解析起確實小好多。當你對xml解析不需要很嚴格時可以使用它。

          下面是使用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) 評論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 福州市| 泸水县| 沙坪坝区| 甘德县| 商洛市| 晴隆县| 宝清县| 陇川县| 大宁县| 进贤县| 广东省| 平昌县| 华阴市| 洛川县| 琼结县| 北安市| 昌乐县| 台前县| 嘉兴市| 富锦市| 康保县| 都安| 林芝县| 德昌县| 黄梅县| 浦江县| 甘孜| 田阳县| 泰安市| 岫岩| 乐昌市| 托克逊县| 方城县| 阜平县| 靖安县| 通江县| 崇文区| 安徽省| 隆安县| 北海市| 阳江市|