android解析xml nbsp报错,XML文件中函数的动态路径是怎么用的啊?

ad680d09ea6cbd3530a322d00b135d90.png

翻翻过去那场雪

一、在Android应用中的XML文件来源1、本地xml文件本地XML文件可以放在应用根目录assets文件夹、res/xml、res/raw、SDcard卡、应用的data目录等;除res/xml可直接通过getXml(int id)获取XML文档,返回一个解析器对象(XmlResourceParer:XmlResourceParer是XmlPullParser的子类),其它位置情况都可以获取XML文档,返回一个Inputstream对象,进行读取数据,获取方法分别如下:a.在res/xml目录下(推荐使用):[java] view plaincopyXmlResourceParser xmlParser = this.getResources().getXml(R.xml.XXX);b.在res/xml、res/raw目录下:[java] view plaincopyInputStream inputStream = this.getResources().openRawResource(R.xml.XXX);c.在assets文件夹下(本人测试发现通过此方法获取的XML文档不能带有首行:<?xml version="1.0" encoding="utf-8"?>,否则解析报错,具体原因未查明,知道原因请回复交流):[java] view plaincopyInputStream inputStream = getResources().getAssets().open(fileName);d.在应用指定目录下(SDcard,应用data目录等):[java] view plaincopy// path路径根据实际项目修改,此次获取SDcard根目录String path = Environment.getExternalStorageDirectory().toString();File xmlFlie = new File(path+fileName);InputStream inputStream = new FileInputStream(xmlFlie);2、通过url得到的xml文件很多时候需要解析xml文件都用于客户端与服务器之间的数据交互,比如解析google天气预报信息,或自己项目内定的一些XML数据结构,其中通过URL,使用DefaultHTTPClient get请求获取XML文件方法如下:[java] view plaincopy/*** 读取url的xml资源 转成String* @param url* @return 返回 读取url的xml字符串*/public String getStringByUrl(String url) {String outputString = "";// DefaultHttpClientDefaultHttpClient httpclient = new DefaultHttpClient();// HttpGetHttpGet httpget = new HttpGet(url);// ResponseHandlerResponseHandler responseHandler = new BasicResponseHandler();try {outputString = httpclient.execute(httpget, responseHandler);outputString = new String(outputString.getBytes("ISO-8859-1"), "utf-8"); // 解决中文乱码Log.i("HttpClientConnector", "连接成功");} catch (Exception e) {Log.i("HttpClientConnector", "连接失败");e.printStackTrace();}httpclient.getConnectionManager().shutdown();return outputString;}二、XML文件的解析方式能够运用在Android系统上解析XML文件的常用有三种方式:DOM、SAX和PULL,其中DOM解析XML是先把XML文件读进内存中,再通过接口获取数据,该方法使用相对小的XML文件,移动设备往往受硬件性能影响,如果XML文件比较大使用DOM解析往往效率跟不上;SAX和PULL都是采用事件驱动方式来进行解析,在Android中的事件机制是基于回调函数。本例旨在考虑简单方便性,综合考虑选择了PULL解析,PULL解析器是一个开源项目,Android平台已经内置了PULL解析器,同时Android系统本身也是使用PULL解析器来解析各种XML文档。1、事件回调类型PULL解析XML文件时,回调XmlResourceParser内定义表示文档开头结束和节点开头结束的数值(事件回调类型),表示如下:a.读取到XML文档开头(声明)返回:XmlPullParser.START_DOCUMENT(0)b.读取到XML文档结束返回:XmlPullParser.END_DOCUMENT (1)c.读取到XML节点开始返回:XmlPullParser.START_TAG (2)d.读取到XML节点结束返回:XmlPullParser.END_TAG (3)e.读取到XML文本返回:XmlPullParser.TEXT (4)2、XmlPullParser有几个主要方法(更多查阅Android APIs):a.XmlPullParser.getEventType() : Returns the type of the current event (START_TAG, END_TAG, TEXT, etc.) 【获取当前事件回调类型】b.XmlPullParser.getName():For START_TAG or END_TAG events, the (local) name of the current element is returned when namespaces are enabled.【获取当前节点名字】c.XmlPullParser.getAttributeValue(int index):Returns the given attributes value.【根据id获取节点属性值】d.XmlPullParser.getAttributeValue(String namespace, String name):Returns the attributes value identified by namespace URI and namespace localName.【根据name获取节点属性值】e.XmlPullParser.netxText():If current event is START_TAG then if next element is TEXT then element content is returned or if next event is END_TAG then empty string is returned, otherwise exception is thrown.【回调节点START_TAG时,通过此方法获取节点内容】3、实际编码中如何使用在实际编码中,主要根据事件回调类型,结合被解析的XML结构进行解析提取数据,PULL解析XML文件的主要模式如下,更具体使用看本文提供的例子:[java] view plaincopytry {//开始解析事件int eventType = parser.getEventType();//处理事件,不碰到文档结束就一直处理while (eventType != XmlPullParser.END_DOCUMENT) {//因为定义了一堆静态常量,所以这里可以用switchswitch (eventType) {case XmlPullParser.START_DOCUMENT:// 不做任何操作或初开始化数据break;case XmlPullParser.START_TAG:// 解析XML节点数据// 获取当前标签名字String tagName = parser.getName();if(tagName.equals("XXXTAGXXX")){// 通过getAttributeValue 和 netxText解析节点的属性值和节点值}break;case XmlPullParser.END_TAG:// 单节点完成,可往集合里边添加新的数据break;case XmlPullParser.END_DOCUMENT:break;}// 别忘了用next方法处理下一个事件,不然就会死循环eventType = parser.next();}} catch (XmlPullParserException e) {e.printStackTrace();}catch (IOException e) {e.printStackTrace();}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值