推荐使用QXmlStreamReader和QXmlStreamWriter处理XML:前者基于事件流、内存友好,适合大文件解析;后者按需生成、自动转义缩进,写入简洁安全。
Qt 处理 XML 文件推荐用 QXmlStreamReader(读)和 QXmlStreamWriter(写),它们是基于事件流的轻量级、高效、内存友好的方案,比 DOM(QDomDocument)更适合大文件或性能敏感场景。
适合解析结构清晰、顺序固定的 XML,比如配置文件、日志、简单数据交换格式。它逐个读取“令牌”(token),如开始标签、文本内容、结束标签等,你需要自己维护上下文状态。
readNext() 推进到下一个元素,再用 tokenType() 判断类型(StartElement、Characters、EndElement 等)StartElement 可用 name() 获取标签名,attributes() 拿属性列表Characters 时用 text().toString() 提取文本内容(注意可能含空白或换行,建议用 isWhitespace() 过滤)depth() 或手动计数(如进入 时 ++,退出时 --)
r:按需生成格式化 XML写 XML 更简单直观——你控制输出顺序,它负责转义、缩进和语法正确性。
QTextStream(可绑定 QFile 或 QByteArray),自动处理编码(默认 UTF-8)writeStartDocument() → writeStartElement("tag") → writeAttribute("key", "value") → writeCharacters("text") → writeEndElement() → writeEndDocument()
setAutoFormatting(true),再设 setAutoFormattingIndent(2)
实际用的时候容易卡在几个细节上:
QFile::open(QIODevice::ReadOnly) 返回 true;写入前确保目录存在、文件可写QXmlStreamReader 不自动跳过注释/处理指令,默认会读到 Comment 或 ProcessingInstruction 类型,不需要就加判断跳过attributes().value("attrName").toString(),避免空指针;写入前可用 QString::isEmpty() 防空字符串写入QXmlStreamReader 默认不验证也不展开,够用;需要验证请换 QXmlSchema + QXmlSchemaValidator
比如处理如下片段:
就取 port 属性和中间文本;用 readNextStartElement() 可简化嵌套逻辑writeStartDocument(),再 writeStartElement("config"),嵌套写 host 并设属性、写文本,最后收尾基本上就这些。不复杂但容易忽略缩进、编码、空格处理这些细节。用熟了,比手拼字符串或硬啃 DOM 快得多也稳得多。