精彩的人生

          好好工作,好好生活

          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 閱讀(684) 評論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 崇仁县| 渑池县| 青川县| 双鸭山市| 浮梁县| 二手房| 九江县| 县级市| 肃南| 和田市| 五家渠市| 黎平县| 大埔县| 无棣县| 嘉兴市| 富锦市| 大庆市| 新乐市| 壤塘县| 乡宁县| 嘉黎县| 河西区| 崇阳县| 宝鸡市| 乌审旗| 义马市| 南华县| 阿勒泰市| 弋阳县| 阳朔县| 夹江县| 奉节县| 武山县| 芒康县| 屯昌县| 龙州县| 丽水市| 鄂托克前旗| 安徽省| 和田市| 锦屏县|