java 解析标记语言_Java 解析xml 使用SAXReader获取所有标签的key和value的代码实例...

Java中使用SAXReader获取xml信息中所有标签的key和value,若是有二级或者继续嵌套,也可以递归获取的代码实例

/**

* @author LiXuekai on 2020/7/26

*/

public class XmlTest2 {

private static final String XML_INFO = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" +

"\n" +

" 20200715\n" +

" 0\n" +

" " +

" 100" +

" 200" +

" \n" +

" N\n" +

" \n" +

" 00000\n" +

" 1001045\n" +

" \n" +

"";

@Test

public void parse() throws DocumentException {

SAXReader sr = new SAXReader();

Document doc = sr.read(new ByteArrayInputStream(XML_INFO.getBytes(StandardCharsets.UTF_8)));

Element root = doc.getRootElement();

getChildNodes(root);

}

public static void getChildNodes(Element element) {

Map map = Maps.newHashMap();

String keyPrefix = "pre";

forkv0(keyPrefix, map, element);

//forkv1(element);

//forkv2(element);

out(map);

}

private static void out(Map map) {

for (Map.Entry entry : map.entrySet()) {

System.out.println(entry.getKey() + " " + entry.getValue());

}

}

private static void forkv0(String keyPrefix, Map map, Element element) {

List elements = element.elements();

for (Object o : elements) {

try {

Element e = (Element) o;

String name = e.getName();

Object data = e.getData();

int size = e.elements().size();

if (size > 0) {

String newKey = keyPrefix + "_" + name;

forkv0(newKey, map, e);

} else {

map.put(keyPrefix + "_" + name, data);

}

//System.out.println("key is " + name + " ; value is " + data + " ; size is " + size);

} catch (Exception ex) {

System.out.println(ex);

}

}

}

private static void forkv2(Element element) {

System.out.println(element.getName());

Iterator it = element.nodeIterator();

while (it.hasNext()) {

Node node = it.next();

//只有标签节点才有子节点 所以判断这个节点是否是标签节点

if (node instanceof Element) {

Element element1 = (Element) node;

forkv2(element1);

}

}

}

private static void forkv1(Element element) {

Iterator iterator = element.elementIterator();

while (iterator.hasNext()) {

Element next = (Element) iterator.next();

Object data = next.getData();

System.out.println(next.getName() + " " + data);

}

}

}

运行结果截图

a2379d932eb102e40b093b6cadc8ef30.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值