Swift解析XML主要用XMLParser配合Delegate,基于事件驱动、低内存;支持从URL、Data初始化,需实现didStartElement、foundCharacters、didEndElement三个回调,注意状态管理、空格处理及错误捕获。
Swift 解析 XML 主要用 XMLParser(iOS 8+ 替代了旧版 NSXMLParser)配合 XMLParserDelegate 协议实现。它基于事件驱动、内存占用低,适合解析中等规模的 XML,但不构建完整 DOM 树,需自己管理状态和数据结构。
支持三种常见初始化方式,按使用场景选择:
let url = Bundle.main.url(forResource: "data", withExtension: "xml")!let parser = XMLParser(contentsOf: url)
let data = xmlString.data(using: .utf8)!let parser = XMLParser(data: data)
if let parser = XMLParser(contentsOf: remoteURL) { ... }(仅限 HTTP/HTTPS 且无认证等限制场景)必须实现 XMLParserDelegate,核心是三个回调方法,顺序固定:开始标签 → 内容字符 → 结束标签。别漏掉状态清理和空格处理。
命名空间、属性字典currentElement = elementName),检查是否为目标节点(如 if elementName == "user"),提取属性(attributes["id"])string.trimmingCharacters(in: .whitespacesAndNewlines) 去除换行/空格;建议累积到临时变量(如 currentValue += string),不要直接 print 或赋值currentValue 是该节点完整文本elementName 判断是否要保存数据(如 if elementName == "name" { user.name = currentValue }),之后清空 currentValue
XML 中常有多个 或嵌套如 ,靠状态机管理:
address 时设 inAddress = true,退出时重置))时,在 didStartElement 中新建模型对象,在 didEndElement 遇到父节点(如 persons)再追加进数组foundCharacters 里直接存值——因为父子节点文本会连续触发,必须结合当前 currentElement 判断归属解析失败很常见,不能只看 parse() 返回值,要主动监听错误和生命周期:
parser(_:, parseErrorOccurred:) 捕获具体错误(如编码不对、标签未闭合)parserDidStartDocument 和 parserDidEndDocument 打印日志,确认是否真正走完全流程foundCharacters 可能为空基本上就这些。不用第三方库也能稳稳解析,关键是理清“事件流 + 状态变量”的配合逻辑。