在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;
}

相关文章

应用场景 C端用户提交工单、工单创建完成之后、会发布一条工...
线程类,设置有一个公共资源 package cn.org.chris.concurre...
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量