//解析XML文件有兩種方式:
//1SAX解析:基于時間驅動的解析方式逐行解析(采用協議回調機制)解析過程若發現錯誤則停止解析使用系統提供的NSXMLParser進行解析OC級別的
//2DOM解析:先讀取完整個文檔內容在內存中形成樹的結構可以根據節點關系訪問樹的i并獲取每個節點包含的數據可以使用系統提供的一個基于C語言的庫libxml2有一些第三方的解析工具:GDataXMLNode:google提供的基于libxml2,進行了OC的封裝
SAX
(Document 文檔 ? ? ?Element? 標簽)
1)
1獲取文件路徑
2創建數據對象
3創建解析對象
NSXMLParser*xml = [[NSXMLParseralloc]initWithData:data];
4設置代理
xml.delegate=self;
5開始解析
[xmlparse];
2)
1開始解析文檔
-(void)parserDidStartDocument:(NSXMLParser
*)parser
{
self.arr= [NSMutableArrayarrayWithCapacity:30];
}
2)model的預創建
-(void)parserDidStartDocument:(NSXMLParser
*)parser{
self.arr= [NSMutableArrayarrayWithCapacity:30];
}
-(void)parser:(NSXMLParser*)parser didStartElement:(NSString*)elementName namespaceURI:(NSString*)namespaceURI qualifiedName:(NSString*)qName attributes:(NSDictionary*)attributeDict{
_currentElement= elementName;
if([elementNameisEqualToString:@"student"
]) {
Student*stu = [Studentnew
];
[
_arraddObject
:stu];
}
}
3)讀取標簽的值
-(void)parser:(NSXMLParser*)parser foundCharacters:(NSString*)string{
Student*stu = [_arrlastObject
];
[stu
setValue:stringforKey:_currentElement
];
}
4)結束標簽解析
-(void)parser:(NSXMLParser*)parser didEndElement:(NSString*)elementName namespaceURI:(NSString*)namespaceURI qualifiedName:(NSString
*)qName{
_currentElement=nil
;
}
5)結束文檔解析
-(void)parserDidEndDocument:(NSXMLParser*)parser{
for(Student*perin_arr
) {
NSLog(@"%@"
,per);
}
}
DOM
1獲取文路徑
2創建data對象
3創建GDataXMLDocument對象
NSError*error;
GDataXMLDocument*xmlDocument = [[GDataXMLDocumentalloc]initWithData:dataoptions:0error:&error];
4獲取根節點
GDataXMLElement*rootElement = [xmlDocumentrootElement];
5創建解析數組
self.arr= [NSMutableArraynew];
6遍歷子節點
for(GDataXMLElement*subElementinrootElement.children) {
Student*stu = [Studentnew];
for(GDataXMLElement*contactElementinsubElement.children) {
[stusetValue:contactElement.stringValueforKeyPath:contactElement.name];
NSLog(@"%@",contactElement.stringValue
);
NSLog(@"%@",contactElement.name);
}
7添加進數組
[_arraddObject
:stu];
}