㈠ 怎样运行android xml解析demo
转载在Android开发中需要解析XML,那么如何解析XML文件呢?
Android参考API中提供了多种方式解析XML,其中之一就是SAX方式。
下面是本人写的一个小Demo.
工程目录如下图所示
需要解析的XML文件如下:
// textxml.xml
<?xml version="1.0" encoding="UTF-8"?>
<users>
<user id="01">
<username>Lucas Cheng</username>
<password>1234</password>
</user>
<user id="02">
<username>David John</username>
<password>6789</password>
</user>
</users>
// 定义User类
package xxx.xxx.xxx;
public class User {
private String id;
private String name;
private String pwd;
public String getId() {
return id;
}
public String getName() {
return name;
}
public String getPwd() {
return pwd;
}
public void setId(String id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
public void setPwd(String pwd) {
this.pwd = pwd;
}
/** 打印出User信息 */
@Override
public String toString() {
return "ID: " + getId() + " Name : " + getName() + " Pwd : "
+ getPwd() + " ";
}
}
// 定义自己的解析XML工具类,继承自DefaultHandler
package xxx.xxx.xxx;
import java.util.ArrayList;
import java.util.List;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import android.util.Log;
public class MyHandler extends DefaultHandler {
private final String TAG = "MyHander";
// 定义XML的标签及标签属性名称
public final String ELE_ROOT = "users";
public final String ELE_USER = "user";
public final String ATTR_USER_ID = "id";
public final String ELE_NAME = "username";
public final String ELE_PWD = "password";
// 定义临时变量
private User user = null;
private StringBuilder text = new StringBuilder();
// 定义变量保存解析结果
public List<User> userList = null;
// 重写父类的以下方法定义自己的解析方式
@Override
public void startDocument() throws SAXException {
Log.d(TAG, "Start document...");
super.startDocument();
}
@Override
public void endDocument() throws SAXException {
super.endDocument();
Log.d(TAG, "End document...");
}
/** 开始解析一个标签时触发 */
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
if (localName.equalsIgnoreCase(ELE_ROOT)) {// 根元素
// 初始化返回User列表
if (null == userList) {
userList = new ArrayList<User>();
} else {
userList.clear();
}
} else if (localName.equalsIgnoreCase(ELE_USER)) {
// new一个User对象,并赋给Id值
user = new User();
user.setId(attributes.getValue(ATTR_USER_ID));
} else if (localName.equalsIgnoreCase(ELE_NAME)) {
// 等待该标签结束时设置内容给user
} else if (localName.equalsIgnoreCase(ELE_PWD)) {
// 等待该标签结束时设置内容给user
} else {
// Nothing to do ...
}
}
/** 解析标签中内容 */
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
// 将标签中内容保存到临时字符串中
text.setLength(0);
text.append(String.valueOf(ch, start, length));
}
/** 结束解析一个标签时触发 */
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
if (localName.equalsIgnoreCase(ELE_ROOT)) {// 根元素
// nothing ...
} else if (localName.equalsIgnoreCase(ELE_USER)) {
userList.add(user);// user加入列表
} else if (localName.equalsIgnoreCase(ELE_NAME)) {
user.setName(text.toString());// 给user设置name
} else if (localName.equalsIgnoreCase(ELE_PWD)) {
user.setPwd(text.toString());// 给user设置pwd
} else {
// Nothing to do ...
}
}
}
// 主程序如下:Main.java
package xxx.xxx.xxx;
import java.io.InputStream;
import java.util.List;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.InputSource;
import org.xml.sax.XMLReader;
import xxx.xxx.xxx.R;
import android.app.Activity;
import android.os.Bundle;
import android.text.method.ScrollingMovementMethod;
import android.view.View;
import android.widget.TextView;
public class Main extends Activity {
private TextView textResult = null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
textResult = (TextView) findViewById(R.id.txt_result);
textResult.setMovementMethod(ScrollingMovementMethod.getInstance());
findViewById(R.id.btn_parse).setOnClickListener(
new View.OnClickListener() {
public void onClick(View v) {
if (null != textResult)
textResult.setText(parseXML());
}
});
findViewById(R.id.btn_clear).setOnClickListener(
new View.OnClickListener() {
public void onClick(View v) {
if (null != textResult)
textResult.setText("");
}
});
}
protected CharSequence parseXML() {
MyHandler handler = new MyHandler();
try {
// 取得XMLReader实例
XMLReader xr = SAXParserFactory.newInstance().newSAXParser()
.getXMLReader();
// 为XMLReader设置处理器
xr.setContentHandler(handler);
// 构建XML输入流
InputSource input = null;
InputStream stream = getApplication().getAssets().open(
"testxml.xml");
input = new InputSource(stream);
// 解析XML
xr.parse(input);
} catch (Exception e) {
e.printStackTrace();
}
List<User> users = handler.userList;
StringBuilder sb = new StringBuilder();
if (null != users) {
for (User u : users) {
sb.append(u.toString()).append(" ");
}
}
return sb;
}
}
㈡ 求问:网站demo是什么意思
demo的意思是样板,例子,小样;
网站demo就是网站案例,网站模板。
㈢ 请问后缀名为.demo的文件怎么打开
工具/原料
word2003 /word2007电脑wps
方法/步骤
1、下载一个WPS即可。
㈣ csgo 怎么看demo 链接
csgo打不开demo怎么解决,csgo观看demo需要把下载的demo解压到csgo目录文件中,然后启动demo控制台播放,下面来看看吧。
1、首先将demo文件解压到csgo文件夹中,如下图所示。
㈤ 网站DEMO是什么意思
demo就是例子、演示的意思
网站demo就是网站的案例,样板,新的模板展示
一般在设计完之后,首先以视觉形式展示给客户体验的作用
㈥ 域名解析的具体操作步骤是怎么样呢
你可以上优时空(vv91)看看。
不过我可以简单介绍。
(1)首先,你要清楚什么叫域名,域名是构成网址的一部分,你把域名输入URL网址,然后通过网址找对应的网站
(2)可是,机器识别的不是你的域名,它识别的是IP地址,所以你输入域名,就要通过解释对应到机器识别的IP,然后找到你的网站
(3)域名解释由DNS服务器完成,一般服务商都会帮你做域名解释。你可以添加A记录是用来指定主机名(或域名)对应的IP地址记录,用户可以将该域名下的网站服务器指向到自己的web server上。
㈦ 网站怎么解析
要网站可以正常访问,网站解析需要做到2点:域名解析到IP 和 网站所在主机绑定域名 两个条件然后就可以访问了。
㈧ ios怎么解析xml的demo
ios中如何解析xml文件
两种方法:1.ios中已有的NSXMLParse类
2.Google的GDataXML也是基于libxml2的,因此在使用GDataXML之前,你需要先导入libxml2。
这里详解ios中的nsxmlparse:
NSXMLParser 实现的是sax方法解析xml文件。
dom实现的原理是把整个xml文档一次性读出,放在一个树型结构里。在需要的时候,查找特定节点,然后对节点进行读或写。他的主要优势是实现简单,读写平衡;缺点是比较占内存,因为他要把整个xml文档都读入内存,文件越大,这种缺点就越明显。
sax的实现方法和dom不同。他只在xml文档中查找特定条件的内容,并且只提取需要的内容。这样做占用内存小,灵活,正好满足我们的需求。他的缺点就是写,有些资料介绍了写入的方法,但是我感觉这对本例没有必要。
运行NSXMLParser涉及设置、运行和响应结果。
1)启动NSXMLParser
要使用NSXMLParser要先创建它,设置各种属性,主要用到以下几个方法:
initWithContentsOfURL 通过NSURL创建解析器
initWithData 通过NSData创建解析器
setDelegate 为解析器定义委托
parse 运行解析器
2)充当委托
最重要的5个方法:
//发现元素开始符的处理函数 (即报告元素的开始以及元素的属性)
- (void)parser:(NSXMLParser *)parser
didStartElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI
qualifiedName:(NSString *)qName
attributes:(NSDictionary *)attributeDict
//处理标签包含内容字符 (报告元素的所有或部分内容)
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
//发现元素结束符的处理函数,保存元素各项目数据(即报告元素的结束标记)
- (void)parser:(NSXMLParser *)parser
didEndElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI
qualifiedName:(NSString *)qName
//报告解析的结束
- (void)parserDidEndDocument:(NSXMLParser *)parser
//报告不可恢复的解析错误
- (void)paser:parserErrorOccured
1.申明了一个xml处理协议,用到NSXMLParser协议,用来具体处理我们要解析的xml文件,把需要的url取出来,存到指定的data里。
*/
//多线程处理类的定义,方法实现,与向主线程回传data
@class AppRecord;
//@protocol ParseOperationDelegate;
@protocol ParseOperationDelegate
- (void)didFinishParsing:(NSArray *)appList;
- (void)parseErrorOccurred:(NSError *)error;
@end
@interface ParseOperation : NSOperation {
@private
id <</span>ParseOperationDelegate> delegate;//,NSXMLParserDelegate
NSData *dataToParse;
NSMutableArray *workingArray;
AppRecord *workingEntry;
NSMutableString *workingPropertyString;
NSArray *elementsToParse;
BOOL storingCharacterData;
}
- (id)initWithData:(NSData *)data delegate:(id <<span class="s13">ParseOperationDelegate>)theDelegate;
@end
然后完成协议的初始化函数
- (id)initWithData:(NSData *)data delegate:(id <<span class="s13">ParseOperationDelegate>)theDelegate
{
self = [super init];
if (self != nil)
{
self.dataToParse = data;
self.delegate = theDelegate;
self.elementsToParse = [NSArray arrayWithObjects:kIDStr, kNameStr, kImageStr, kArtistStr, nil];
}
return self;
}
2.完成对特定标签的解析
#pragma mark -
#pragma mark RSS processing
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI
qualifiedName:(NSString *)qName
attributes:(NSDictionary *)attributeDict
{
// entry: { id (link), im:name (app name), im:image (variable height) }
//
if ([elementName isEqualToString:kEntryStr])
{
self.workingEntry = [[[AppRecord alloc] init] autorelease];
}
storingCharacterData = [elementsToParse containsObject:elementName];
}
3.找到具体的地址与内容,并存储
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI
qualifiedName:(NSString *)qName
{
if (self.workingEntry)
{
if (storingCharacterData)
{
NSString *trimmedString = [workingPropertyString :
[NSCharacterSet ]];
[workingPropertyString setString:@""]; // clear the string for next time
if ([elementName isEqualToString:kIDStr])
{
self.workingEntry.appURLString = trimmedString;
}
else if ([elementName isEqualToString:kNameStr])
{
self.workingEntry.appName = trimmedString;
}
else if ([elementName isEqualToString:kImageStr])
{
self.workingEntry.imageURLString = trimmedString;
}
else if ([elementName isEqualToString:kArtistStr])
{
self.workingEntry.artist = trimmedString;
}
}
else if ([elementName isEqualToString:kEntryStr])
{
[self.workingArray addObject:self.workingEntry];
self.workingEntry = nil;
}
}
}
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{
if (storingCharacterData)
{
[workingPropertyString appendString:string];
}
}
第三方解析方法::::::::::::
简介:采用KissXML第三方程序集来实现,需要引入libxml2.dylib
(另需注意运行时可能会提示“libxml/tree.h找不到“的问题,
解决办法: 在项目的 TARGETS 中选择一个目标,在右侧切换到 Build Settings 页,向下找到 Search
Paths 段,其中有一个 Header Search Paths 项,将其值设为:/usr/include/libxml2)如下图:
ProvinceCity.xml文件格式如下图:
程序主要代码如下:
#import"DDXML.h"
#import"DDXMLElementAdditions.h"
@implementation ViewController
//解析XML
staticNSString *kXML =@"//District//Province";
- (void)viewDidLoad
{
[superviewDidLoad];
NSString *path =[[NSStringalloc]initWithString:[[NSBundlemainBundle]pathForResource:@"ProvinceCity"ofType:@"xml"]];
NSData *data = [[NSDataalloc]initWithContentsOfFile:path];
[selfparsedDataFromData:dataandProvince:@"江西省"];
[selfparsedDataFromData:data];
[datarelease];
}
//取特定省份下包含所有城市
-(void)parsedDataFromData:(NSData *)data andProvince:(NSString *)province{
DDXMLDocument *doc = [[DDXMLDocumentalloc]initWithData:dataoptions:0error:nil];
/////解析
NSArray *items = [docnodesForXPath:kXMLerror:nil];
for (DDXMLElement *objin items) {
DDXMLNode *aUser = [obj attributeForName:@"Name"];//取属性Name的值
if ([aUser.stringValueisEqualToString:province])
{
NSArray *CityLst = [obj elementsForName:@"City"];//取城市点点列表,保存到数组中
if(CityLst.count>0)//第二层
{
for (DDXMLElement *citysin CityLst) {
DDXMLNode *citynode=[citys attributeForName:@"Name"];
NSLog(@"%@",citynode.stringValue);
}
}
}
}
[doc release];
}
//取所有省份及其下级节点,包含修改操作
-(void)parsedDataFromData:(NSData *)data{
DDXMLDocument *doc = [[DDXMLDocumentalloc]initWithData:dataoptions:0error:nil];
/////解析
NSArray *items = [docnodesForXPath:kXMLerror:nil];
for (DDXMLElement *objin items) {
DDXMLNode *aUser = [objattributeForName:@"Name"];//取属性Name的值
//[aUser setStringValue:@"haha!"];//修改属性节点的值
[objaddAttribute:[DDXMLNodeattributeWithName:@"test"stringValue:@"wzh"]];//增加一个属性节点
[objaddAttributeWithName:@"ttt"stringValue:@"343"];//再增加一个属性节点
//[obj setStringValue:@"NewNode"];//设置当前节点的值
DDXMLNode *newnode=[DDXMLNodeelementWithName:@"newNode"];//设置一个新的节点
[obj addChild:newnode];//给obj添加一个节点
DDXMLElement *newdxml = [[objelementsForName:@"newNode"]objectAtIndex:0];//访问刚刚添加的节点
[newdxmladdAttributeWithName:@"nodetwo"stringValue:@"twovalue"];//给刚添加的节点增加增的下级节点,并且下级节点再一个属性值
DDXMLNode *newnode2=[DDXMLNodeelementWithName:@"newNode2"stringValue:@"hello!"];
[newdxmladdChild:newnode2];
}
//保存到沙盒目录下
NSString *path =[[NSStringalloc]initWithFormat:@"%@/xmlData.xml", [(NSDocumentDirectory,NSUserDomainMask,YES)objectAtIndex:0]];
NSString *result=[[NSStringalloc]initWithFormat:@"%@",doc];
[resultwriteToFile:pathatomically:YESencoding:NSUTF8StringEncoding error:nil];
//[result2 writeToFile:path atomically:YES];//这种方法不行,保存后会有乱码
[result release];
[path release];
[doc release];
}
㈨ 网站域名解析要怎么做
域名解析是把域名指向固定的服务器ip地址上,正常在购买域名的平台中都有解析这个功能的。
一、登录域名购买的服务商之后查看到你的域名
二、点开域名找到解析的按钮。
三、然后会出现一系列的解析方式,有解析记录选择,主要看你的域名用途,如果是网站就选择a记录就行了。
四、当下面解析添加好之后。正常就行了