我可以用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;
}