在Java中使用SAX解析XML,不区分大小写.

前端之家收集整理的这篇文章主要介绍了在Java中使用SAX解析XML,不区分大小写.前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我可以用Java中的SAXParserFactory解析xml,但是在某些文件中,
存在一些非小写属性,如linear3D =“0.5”等.

我想以某种方式制作

attributes.getValue(attr)

不区分大小写,以便attributes.getValue(“linear3d”)返回“0.5”.

一种解决方案是首先将文件作为字符串读取,转换为小写,然后解析,
因为在这种类型的xml中这样做没有歧义.
但是,通过在工厂或类似地方添加一些标志,可以更简单地完成吗?

最佳答案
而不是将整个文件转换为小写,以下方法更好.这将遍历所选标记的所有属性,并忽略大小写.

在DefaultHandler的实现中,编写以下方法

private String getValueIgnoreCase(Attributes attributes,String qName){
    for(int i = 0; i < attributes.getLength(); i++){
        String qn = attributes.getQName(i);
        if(qn.equalsIgnoreCase(qName)){
            return attributes.getValue(i);
        }
    }
    return null;
}

猜你在找的Java相关文章