android读取xml文件来实现省份,城市,区的选择
本博客如需转载。请注明出处。
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
今天要实现省份,城市。区的选择,到网络上百度了一下。发现非常多实现都是用的sqlite数据库,可是我这边为了保证和ios那边数据统一,仅仅要用那边的plist文件。也就是我们常说的xml文件。就想找一个网络上读取xml文件来实现的。发现基本没有,就算有。也是把所有的资源所实用数组列举出来,而不是实时读取。
网络上的实现:
1.利用sqlite訪问db数据库。
2.列举出全部的xml资源。
我的实现:
1.动态读取xml文件。
2.须要什么读取什么,假设获取了想要的资源。则停止读取。
3.异步读取。
改进:
1.读取的资源没有进行缓存。这个看详细需求吧。
2.代码实现算法能够进行优化。
3.xml文件结构能够优化,这个是ios那边直接给我的资源。可是看着非常无语,city.xml比較少,就直接手动改动了一下,area.xml文件比較多,就没改了。
建议:
这个博客仅仅是给大家提供了一个实现的思路,大家不好照搬,最好依据自己的需求来详细实现,最好是换一个结构更加合理的xml文件,在实现一个比較优秀的算法。切记,本博客仅仅是提供一个思路!~。~
city.xml的基本结构
<?xml version="1.0" encoding="UTF-8"?>
<array>
<dict>
<key>state</key>
<string>北京</string>
<key>cities</key>
<array>
<string>通州</string>
<string>房山</string>
<string>昌平</string>
<string>顺义</string>
<string>怀柔</string>
<string>大兴</string>
<string>密云</string>
<string>平谷</string>
<string>延庆</string>
<string>东城</string>
<string>崇文</string>
<string>西城</string>
<string>朝阳</string>
<string>宣武</string>
<string>石景山</string>
<string>丰台</string>
<string>门头沟</string>
<string>海淀</string>
</array>
</dict>
....
</array>
1.读取城市的代码
/**
* 获取省份数据列表
*/
private List<String> getProvince(){
//结果存储
List<String> resultList = new ArrayList<String>();
//标记是否读取下一个节点的内容
boolean nextRead = false;
try {
XmlPullParser xrpCity = Xml.newPullParser();
xrpCity.setInput(getAssets().open("city.xml"), "UTF-8");
while (xrpCity.getEventType() != XmlPullParser.END_DOCUMENT) {
//假设是開始标签
if (xrpCity.getEventType() == XmlPullParser.START_TAG) {
//获取标签名称
String name = xrpCity.getName();
//推断标签名称是否等于friend
if("key".equals(name)){
xrpCity.next();
String value = xrpCity.getText();
if("state".equals(value)){
nextRead = true;
}
}else if("string".equals(name) && nextRead){
xrpCity.next();
resultList.add(xrpCity.getText());
nextRead = false;
}
}
//下一个标签
xrpCity.next();
}
} catch (XmlPullParserException e) {
// TODO Auto-generated catch block
e.printStackTrace();
resultList = null;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
resultList = null;
}
return resultList;
}
2.读取城市的代码
/**
* 获取城市列表
*/
private List<String> getCity(String provinceName){
//结果存储
List<String> resultList = new ArrayList<String>();
//标记是否读取下一个节点的内容
boolean nextRead = false;
//读取城市节点内容的标记
boolean readCity = false;
try {
XmlPullParser xrpCity = Xml.newPullParser();
xrpCity.setInput(getAssets().open("city.xml"), "UTF-8");
while (xrpCity.getEventType() != XmlPullParser.END_DOCUMENT) {
//假设是開始标签
if (xrpCity.getEventType() == XmlPullParser.START_TAG) {
//获取标签名称
String name = xrpCity.getName();
if("key".equals(name)){
xrpCity.next();
String value = xrpCity.getText();
if("state".equals(value)){
nextRead = true;
if(readCity){
break;
}
readCity = false;
}
}else if("string".equals(name) && nextRead){
xrpCity.next();
nextRead = false;
if(provinceName.equals(xrpCity.getText())){
readCity = true;
}
}else if("string".equals(name) && readCity){
xrpCity.next();
resultList.add(xrpCity.getText());
}
}
//下一个标签
xrpCity.next();
}
} catch (XmlPullParserException e) {
// TODO Auto-generated catch block
e.printStackTrace();
resultList = null;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
resultList = null;
} return resultList;
}
area.xml资源的基本结构
<?xml version="1.0" encoding="UTF-8"?>
<array>
....
<dict>
<key>areas</key>
<array>
<string>连山壮族瑶族自治县</string>
<string>阳山县</string>
<string>佛冈县</string>
<string>清城区</string>
<string>连南瑶族自治县</string>
<string>清新县</string>
<string>英德市</string>
<string>连州市</string>
</array>
<key>city</key>
<string>清远</string>
</dict>
.....
</array>
1.读取区的代码
/**
* 获取区列表
*/
private List<String> getRegion(String citName){
//结果存储
List<String> resultList = new ArrayList<String>();
//标记是否读取下一个节点的内容
boolean nextRead = false;
//读取城市节点内容的标记
boolean readCity = false;
try {
XmlPullParser xrpCity = Xml.newPullParser();
xrpCity.setInput(getAssets().open("area.xml"), "UTF-8");
while (xrpCity.getEventType() != XmlPullParser.END_DOCUMENT) {
//假设是開始标签
if (xrpCity.getEventType() == XmlPullParser.START_TAG) {
//获取标签名称
String name = xrpCity.getName();
if("key".equals(name)){
xrpCity.next();
String value = xrpCity.getText();
if("areas".equals(value)){
nextRead = true;
readCity = false;
}else if("city".equals(value)){
readCity = true;
nextRead = false;
}
}else if("string".equals(name) && nextRead){
xrpCity.next();
resultList.add(xrpCity.getText());
}else if("string".equals(name) && readCity){
xrpCity.next();
if(citName.equals(xrpCity.getText())){
break;
}else{
resultList.clear();
}
}
}
//下一个标签
xrpCity.next();
}
} catch (XmlPullParserException e) {
// TODO Auto-generated catch block
e.printStackTrace();
resultList = null;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
resultList = null;
} return resultList;
}
上面就是基本的实现,待会把功能做个小项目,传到csdn之后。在给出demo地址,和资源。
地址例如以下:http://download.csdn.net/detail/jiguangcanhen/8152421
该项目为ant架构,gradle架构的懒得弄了,自己搞定吧。
android读取xml文件来实现省份,城市,区的选择的更多相关文章
- Android - 读取XML文件中的数据
读取XML中存储的数据.将xmlfile.xml存放在assets文件夹中.在activity_main.xml中创建一个textview,用来显示读取到的数据. XML文件内容如下:xmlfile. ...
- unity Android 打包后读取 xml 文件
原地址:http://www.cnblogs.com/wuzhang/p/wuzhang20140731.html 问题: 前天在做东西的过程中发现了一个让人很纠结的问题,为什么Unity 程序 ...
- Android 开发自己的网络收音机4——读取XML文件的电台数据
国内外的电台数据很多,起码有好几百,所以把这些数据都写到代码里面是不实际的.只能写成一个数据文件,程序启动的时候再去加载.保存这些简单数据,我们肯定会优先使用XML文件,今天讲讲如何读取XML里面的数 ...
- Android通过xml文件配置数据库
之前一段时间自己封装了两个数据库,一个是ORM数据库,另一个是事件流数据库,项目相应的地址如下: ORM数据库:https://github.com/wenjiang/SimpleAndroidORM ...
- cocos2dx中调用TinyXml读取xml配置文件 || cocos2d-x 中跨平台tinyxml读取xml文件方式
TiXmlDocument *doc = newTiXmlDocument; #if (CC_TARGET_PLATFORM ==CC_PLATFORM_ANDROID) //Android平台tin ...
- android解析xml文件的方式
android解析xml文件的方式 作者:东子哥 ,发布于2012-11-26,来源:博客园 在androd手机中处理xml数据时很常见的事情,通常在不同平台传输数据的时候,我们就可能使用xm ...
- C#中常用的几种读取XML文件的方法
1.C#中常用的几种读取XML文件的方法:http://blog.csdn.net/tiemufeng1122/article/details/6723764/
- 读取xml文件报错:Invalid byte 2 of 2-byte UTF-8 sequence。
程序读取xml文件后,系统报“Invalid byte 2 of 2-byte UTF-8 sequence”错误,如何解决呢? 1.程序解析xml的时候,出现Invalid byte 2 of 2- ...
- C#读取XML文件的基类实现
刚到新单位,学习他们的源代码,代码里读写系统配置文件的XML代码比较老套,直接写在一个系统配置类里,没有进行类的拆分,造成类很庞大,同时,操作XML的读写操作都是使用SetAttribute和node ...
随机推荐
- ZOJ 4009 And Another Data Structure Problem(ZOJ Monthly, March 2018 Problem F,发现循环节 + 线段树 + 永久标记)
题目链接 ZOJ Monthly, March 2018 Problem F 题意很明确 这个模数很奇妙,在$[0, mod)$的所有数满足任意一个数立方$48$次对$mod$取模之后会回到本身. ...
- Python的Web编程[0] -> Web客户端[0] -> 统一资源定位符 URL
统一资源定位符 / URL 目录 URL 构成 URL 解析 URL 处理 1 URL构成 统一资源定位符(Uniform Resource Locator) 是对可以从互联网上得到的资源的位置和访问 ...
- Python的网络编程[1] -> FTP 协议[2] -> 使用 ftplib 建立 FTP 客户端
使用 ftplib 建立 FTP 客户端 用于建立FTP Client,与 pyftplib 建立的 Server 进行通信. 快速导航 1. 模块信息 2. 建立 FTP 客户端 1. 模块信息 1 ...
- UBIFS介绍 - MTD网站
转:http://blog.csdn.net/kickxxx/article/details/6583463 目录(?)[-] Big red note Overview Scalabity Writ ...
- 【Mysql】字段排序中文排序
在mysql中 如果字段的值是中文的话,排序结果往往不符合人意. 所以如果要中文排序正常的话,可以使用如下函数 SELECT huayangare0_.id AS id1_0_, huayangare ...
- Hibernate中cascade和inverse的作用
Inverse和cascade是Hibernate映射中最难掌握的两个属性.两者都在对象的关联操作中发挥作用.1.明确inverse和cascade的作用inverse 决定是否把对对象中集合的改动反 ...
- 记一次有惊无险的Linux数据恢复过程
问题阶段 起因: 昨天晚上思路不是很清晰(上了一天班回来有点蒙),还是强忍着疲惫想搞事情,结果悲剧了… … 本来想拿SD卡做一张linux烧录卡,烧录脚本是很久以前写的,有git记录,一直不成功,就回 ...
- Linux下自动监测并重启Apache服务脚本
为了达到一个高可用的基于Apache的网站环境,在Apache由于种种原因自动停止运行之后,想立即恢复网站访问,这就需要有个工具实时监测Apache的运行状态并能够自动重启httpd服务,写了一个简单 ...
- Android.mk入门(一)
Android.mk是Android工程管理文件,其作用基本等同于Linux环境中的Makefile,在语法上,Android.mk和普通Makefile略有不同,主要区别是Android.mk包含一 ...
- object references an unsaved transient instance - save the transient instance before flushing异常问题处理
一.异常:org.hibernate.TransientObjectException: object references an unsaved transient instance - save ...