0

我试图用一些 Unicode 字符获取 XML 输出。我无法读取标签内的完整字符串,只能读取一个。

这是我的 XML 输出

 <item>
    <id>1</id>    
    <name>&#x0DBD;&#x0DDC;&#x0DBD;&#x0DCA;</name>
    <cost>155</cost>
    <description>&#x0DBD;&#x0DDC;</description>
</item> 

这是我用来解析 XML 字符串的 java 代码。

    public Document getDomElement(String xml) {
Document doc = null;
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
try {

    DocumentBuilder db = dbf.newDocumentBuilder();

    InputSource is = new InputSource();
    is.setEncoding("UTF-16");
    is.setCharacterStream(new StringReader(xml));
    doc = db.parse(is);

} catch (ParserConfigurationException e) {
    Log.e("Error: ", e.getMessage());
    return null;
} catch (SAXException e) {
    Log.e("Error: ", e.getMessage());
    return null;
} catch (IOException e) {
    Log.e("Error: ", e.getMessage());
    return null;
}
// return DOM
return doc;
}

当我使用普通英文字符时,它会给出完整的字符串。

4

3 回答 3

1

我试过你的代码,没有问题。如果我使用非英语字符评估节点,则存在并且具有正确数量的字符。它们不可打印,因为我没有使用字体中的字形,但value.codePointAt(i)返回正确的代码点。

    NodeList list = doc.getDocumentElement().getChildNodes();
    for (int i=0; i<list.getLength(); i++)
    {
        String value = list.item(i).getTextContent();
        for (int j=0; j<value.length(); j++)
            System.out.print(" " + value.codePointAt(j));
        System.out.println();
    }

输出:

 49
 3517 3548 3517 3530
 49 53 53
 3517 3548

这对应于您的代码点的十进制表示。

我已经手动创建了 xml 字符串。你已经在记忆中了吧?

于 2012-09-21T07:53:44.633 回答
0
  • 通过 Unicode,人们通常指的是 UTF-8,但您使用的是 UTF-16,这很糟糕

  • XML 在其标头中定义了自己的编码,因此您不需要覆盖它

于 2012-09-21T07:41:31.970 回答
0

这是我用来解决问题的代码。

   NodeList idlist = doc.getElementsByTagName(KEY_ID);
    NodeList namelist = doc.getElementsByTagName(KEY_NAME);
    NodeList costlist = doc.getElementsByTagName(KEY_COST);
    NodeList desclist = doc.getElementsByTagName(KEY_DESC);
    for (int i=0; i<idlist.getLength(); i++)
    {
        Item item = new Item();
        item.setCost(costlist.item(i).getTextContent());
        item.setDescription(desclist.item(i).getTextContent());
        item.setName(namelist.item(i).getTextContent());
        itemarray.add(item);

    }
于 2012-09-21T10:20:49.077 回答