Android解析plist到文档

时间:2011-04-21 08:58:49

标签: android parsing plist

我正在尝试解析iPhone plist文件,以便将其与xpath和xpathexpression一起使用。

plist示例:

<plist version="1.0">
    <dict>
        <key>00</key>
        <dict>
            <key>pkw</key>
            <dict>
                <key>gas</key>
                <integer>0</integer>
                <key>diesel</key>
                <dict>
                    <key>ohne</key>
                    <integer>0</integer>
                    <key>pm01</key>
                    <integer>0</integer>
                    <key>pm0</key>
                    <integer>0</integer>
                    <key>pm1</key>
                    <integer>0</integer>
                    <key>pm2</key>
                    <integer>0</integer>
                    <key>pm3</key>
                    <integer>0</integer>
                    <key>pm4</key>
                    <integer>0</integer>
                    <key>pm5</key>
                    <integer>4</integer>
                </dict>
                <key>otto</key>
                <integer>0</integer>
            </dict>
        </dict>
    </dict>
</plist>

使用以下代码我得到SAXParserException

  

预期名称(位置:在java.io.InputStreamReader@43e395f0中START_TAG @ 3:41)

    DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
builderFactory.setNamespaceAware(true);
DocumentBuilder builder = null;
try {
    builder = builderFactory.newDocumentBuilder();
} catch (ParserConfigurationException e1) {
    // TODO Auto-generated catch block
    e1.printStackTrace();
}

Document document = null;
try {
    document = builder.parse(getApplicationContext().getResources().openRawResource(R.xml.finedust));
} catch (NotFoundException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
} catch (SAXException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}

也许有人有想法?

1 个答案:

答案 0 :(得分:3)

问题是,您正在尝试从res / xml /文件夹(R.xml.finedust)加载plist xml文档作为原始资源。

您应该将xml文件放在res / raw /文件夹(res / raw / findedust.xml)中,然后通过R.raw.finedust访问它。

所以你的document初始化将是:

document = builder.parse(getApplicationContext().getResources().
    openRawResource(R.raw.finedust));

这样就行了!

<强>已过时

您已打开4个<dict>标记,但只有3个标记具有匹配的关闭标记。

您的<dict>标签之一 - 可能是第一个 - 未关闭!你应该检查你的输入,当你搞清楚时,关闭它,然后它会解析xml。

除非文档格式正确(但不一定有效),否则无法进行解析。