本文中解析文件的方法是通过jar包dom4j实现的,下面做个简单的总结:
文件内容:
java代码:
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class Tools {
public static void main(String[] args) {
String fileUrl = "https://**/Collect_20190110180259.xml";
readXmlFile(fileUrl);
}
/**
*解析文件数据
* @param areaFileUrl
* @return List<Map<String,Object>>
* @throws Exception
*/
public static void readXmlFile(String fileUrl){
//fileUrl为文件全路径
if(fileUrl !=null && !"".equals(fileUrl)){
try{
HttpURLConnection connection = null;
InputStream input = null;
connection = (HttpURLConnection)new URL(fileUrl).openConnection();
input = connection.getInputStream();
SAXReader reader = new SAXReader();
Document doc = reader.read(input);
Element root = doc.getRootElement();
System.out.println("当前节点1的名称:" + root.getName());
List<Element> dataList = root.elements();//节点中的所有元素
for (int i = 0; i < dataList.size(); i++) {
Element itemModel = (Element) dataList.get(i);
Attribute attribute = itemModel.attribute("Count");//根据属性名称获取节点内的属性
String attributeName = attribute.getValue();
System.out.println("当前节点2的名称:" + itemModel.getName());
System.out.println("当前节点2的属性:" + attributeName);
List modelList = itemModel.elements();
for (int j = 0; j < modelList.size(); j++) {
Element model = (Element) modelList.get(j);
System.out.println("当前节点3名称:" + model.getName());
Element modelNameElm = model.element("ModelName");//根据子节点名称获取子节点元素
String code = modelNameElm.getText();//获取节点里面的字符串
System.out.println("当前节点3内ModelName节点内的字符串:" + code);
Element indexElm = model.element("Index");
String indexStr = indexElm.getText();
System.out.println("当前节点3内Index节点内的字符串:" + indexStr);
}
}
}catch(Exception e){
e.printStackTrace();
}
}
}
}
运行结果:
当前节点1的名称:Data
当前节点2的名称:ItemModel
当前节点2的属性:2
当前节点3名称:Model
当前节点3内ModelName节点内的字符串:20100
当前节点3内Index节点内的字符串:000001
当前节点3名称:Model
当前节点3内ModelName节点内的字符串:20200
当前节点3内Index节点内的字符串:000002