展开全部
这个简单,循环一下节点,如果为空就删除import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class MyTest {
public static void main(String[] args) {
try {
removeNullValueNode();
} catch (Exception e) {
// TODO 自动生成された catch ブロック
e.printStackTrace();
}
}
public static void removeNullValueNode() throws Exception {
// 解析xml文件
String xmlContent = "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>null李三";
System.out.println("原始e69da5e6ba903231313335323631343130323136353331333335333161内容:\r\n" + xmlContent);
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder db = factory.newDocumentBuilder();
// 根据xml内容构建document:当然这可以直接加载文件流
Document doc = db.parse(new ByteArrayInputStream(xmlContent.getBytes()));
// A节点
Element elmtInfo = doc.getDocumentElement();
// A节点下的子节点
NodeList nodes = elmtInfo.getChildNodes();
for (int i = 0; i
Node result = nodes.item(i);
if (result.getNodeType() != Node.ELEMENT_NODE) {
// 如果不是元素节点跳过
continue;
}
if (null == result.getTextContent()
|| "null".equals(result.getTextContent())) {
// 删除本节点
elmtInfo.removeChild(result);
}
}
// XML转字符串
TransformerFactory tf = TransformerFactory.newInstance();
Transformer t = tf.newTransformer();
t.setOutputProperty("encoding", "utf-8");
ByteArrayOutputStream bos = new ByteArrayOutputStream();
t.transform(new DOMSource(doc), new StreamResult(bos));
String xmlStr = bos.toString("utf-8");
// 输出删除节点后的xml类容
System.out.println("删除空节点后的内容:\r\n" + xmlStr);
}
}