使用Swift實(shí)現(xiàn)iOS App中解析XML格式數(shù)據(jù)的教程
在IOS中,提供了一套解析XML數(shù)據(jù)的API。其實(shí)也很簡(jiǎn)單,就是NSXMLParser和NSXMLParserDelegate。
可以直接指定到XML的URL去實(shí)例化NSXMLParser
public convenience init?(contentsOfURL url: NSURL)
解析文件,返回的是一次解析的結(jié)果
NSXMLParser.parse() -> Bool
監(jiān)聽(tīng)解析節(jié)點(diǎn)的屬性
NSXMLParserDelegate.parser(parser: NSXMLParser, didStartElement elementName: String, namespaceURI: String?, qualifiedName qName: String?, attributes attributeDict: [String : String])
監(jiān)聽(tīng)解析節(jié)點(diǎn)的內(nèi)容
NSXMLParserDelegate.parser(parser: NSXMLParser, foundCharacters string: String)
示例:
這里介紹基本的xml數(shù)據(jù)解析并打印出來(lái).
1.準(zhǔn)備xml數(shù)據(jù)
打開(kāi)記事本,寫(xiě)下:
<?xml version="1.0" encoding="utf-8" ?>
<students>
<student id="001">
<name>Bill Gates</name>
<age>15</age>
</student>
<student id="002">
<name>Tim Cook</name>
<age>18</age>
</student>
</students>
保存命名為data.xml.
2.解析xml
在Xcode中新建一個(gè)項(xiàng)目,把data.xml導(dǎo)入新建的工程中,直接拖進(jìn)去好了.在ViewController.swift里寫(xiě)下如下代碼:
class ViewController: UIViewController,NSXMLParserDelegate{
override func viewDidLoad() {
super.viewDidLoad()
let parser = NSXMLParser(contentsOfURL: NSURL(fileURLWithPath: NSBundle.mainBundle().pathForResource("data", ofType: "xml")!))
//1
parser!.delegate = self
parser!.parse()
}
var currentNodeName:String!
func parser(parser: NSXMLParser, didStartElement elementName: String, namespaceURI: String?, qualifiedName qName: String?, attributes attributeDict: [String : String]) {
currentNodeName = elementName
if elementName == "student"{
if let id = attributeDict["id"]{
print("id:\(id)")
}
}
}
func parser(parser: NSXMLParser, foundCharacters string: String) {
//2
let str = string.stringByTrimmingCharactersInSet(NSCharacterSet.whitespaceAndNewlineCharacterSet())
if str != "" {
print("\(currentNodeName):\(str)")
}
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}
代碼注釋:
1.使用NSXMLParser需要NSXMLParserDelegate代理
2.去除打印如<student>的標(biāo)簽,如果直接寫(xiě)成
func parser(parser: NSXMLParser, foundCharacters string: String) {
print("\(string):\(str)")
}
將會(huì)把前面的標(biāo)簽打印出來(lái).
3.代碼運(yùn)行結(jié)果
id:001 name:Bill Gates age:15 id:002 name:Tim Cook age:18
相關(guān)文章
用SwiftUI實(shí)現(xiàn)3D Scroll滾動(dòng)效果的實(shí)現(xiàn)代碼
這篇文章主要介紹了用SwiftUI實(shí)現(xiàn)3D Scroll效果的實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)2020-04-04
Swift讓輸入框跟隨鍵盤(pán)彈起避免輸入輸入法擋住輸入框問(wèn)題
這篇文章主要介紹了Swift讓輸入框跟隨鍵盤(pán)彈起避免輸入輸入法擋住輸入框問(wèn)題的完美解決方案,本文分步驟給大家介紹的非常詳細(xì),需要的朋友可以參考下2016-11-11
SwiftUI 登錄界面布局實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了SwiftUI 登錄界面布局實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
Swift使用編解碼庫(kù)Codable的過(guò)程詳解
Codable 是 Swift 引入的全新的編解碼庫(kù),使開(kāi)發(fā)者更方便的解析JSON 或 plist 文件,支持枚舉、結(jié)構(gòu)體和類(lèi),這篇文章主要介紹了Swift使用編解碼庫(kù)Codable,需要的朋友可以參考下2023-09-09
Flutter iOS開(kāi)發(fā)OC混編Swift動(dòng)態(tài)庫(kù)和靜態(tài)庫(kù)問(wèn)題填坑
這篇文章主要為大家介紹了Flutter iOS OC 混編 Swift動(dòng)態(tài)庫(kù)和靜態(tài)庫(kù)問(wèn)題填坑詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
SwiftUI?List在MacOS中的性能優(yōu)化示例
這篇文章主要為大家介紹了SwiftUI?List在MacOS中的性能優(yōu)化示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
Swift踩坑實(shí)戰(zhàn)之一個(gè)字符引發(fā)的Crash
swift通常都是通過(guò)對(duì)應(yīng)的signal來(lái)捕獲crash,下面這篇文章主要給大家介紹了關(guān)于Swift踩坑實(shí)戰(zhàn)之一個(gè)字符引發(fā)的Crash的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-02-02
使用Swift實(shí)現(xiàn)iOS App中解析XML格式數(shù)據(jù)的教程
這篇文章主要介紹了使用Swift實(shí)現(xiàn)iOS App中解析XML格式數(shù)據(jù)的教程,講到了iOS中提供的NSXMLParser和NSXMLParserDelegate兩個(gè)API的用法,需要的朋友可以參考下2016-04-04

