我有一个本地xml文件告诉我:
这是一个模板:
<?xml version="1.0" encoding="utf-8"?>
<parameters version="2.0">
<page pageNum = "2">
<row colNum = "1">
<column>
<id>00001</id>
<name>parameterName</name>
<type>parameterType</type>
<value>parameterValue</value>
<min>0</min>
<max>100</max>
<step>1</step>
</column>
</row>
<row colNum = "2">
<column>
<id>00002</id>
<name>parameterName</name>
<type>parameterType</type>
<value>parameterValue</value>
<min>0</min>
<max>100</max>
<step>1</step>
</column>
<column>
<id>00003</id>
<name>parameterName</name>
<type>parameterType</type>
<value>parameterValue</value>
<min>0</min>
<max>100</max>
<step>1</step>
</column>
</row>
</page>
<page>
<!-- ... etc ... -->
</page>
</parameters>
经过一些研究后,我在一些论坛中发现XmlListModel不合适。 考虑到我在Qt工作,我该怎么办?
这里https://lists.launchpad.net/ubuntu-phone/msg12284.html我发现了一些有趣的东西,但是读取xml文件时使用的是XMLHttpRequest,我无法使用,因为我的xml文件只是本地的!
有人可以帮助我吗?
非常感谢你!
答案 0 :(得分:0)
虽然这几乎可以肯定用XmlListModel
完成(请参阅对问题的评论),但这会非常浪费,因为模型的每个实例都需要进行所有的解析和查询。
一个XmlListModel
将提供有多少页面的输入
XmlListModel {
query: "/parameters/page"
}
然后每个页面都有一个模型,用于提取该页面的行(查询未测试)
XmlListModel {
// pageNum is a property set on each page, e.g. via the model.index of the Repeater generating the pages
query: "/parameters/page[@pageNum=" + pageNum + "]/row"
XmlRole { name: "id"; query: "column/id/string()" }
// ... and so on
}
但是,我认为最好的方法是创建一个可以表示单个页面行的自定义QAbstractListModel
子类。
然后,具有该类型的list属性的对象可以用作页面的模型,每个页面使用其“行模型”。
仅解析一次,例如使用QXmlStreamReader
构建“行模型”列表并获取每个行的内容。