XMl各种格式转换功能代码
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.StringReader;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.jdom2.input.SAXBuilder;
import org.jdom2.output.Format;
import org.jdom2.output.XMLOutputter;
import org.w3c.dom.Document;
import org.xml.sax.InputSource;
public class XmlKit {
/**
* dom4j解析xml
*/
public static org.dom4j.Document xmlTodDocDom4j(String path){
File file = new File(path);
org.dom4j.Document doc = null;
try {
doc = new SAXReader().read(file);
} catch (DocumentException e) {
e.printStackTrace();
}
return doc;
}
public static String docToString(org.dom4j.Document document){
String xmlStr = document.asXML();
return xmlStr;
}
public static org.dom4j.Document stringToXmlDom4j(String xmlStr){
org.dom4j.Document doc = null;
try {
doc = DocumentHelper.parseText(xmlStr);
} catch (DocumentException e) {
e.printStackTrace();
}
return doc;
}
/**
* Document 保存为 XML 文件
*
* @param doc Document对象
* @param path 文件路径
*/
public static void doc2XMLDom4j(org.dom4j.Document doc, String path) {
try {
XMLWriter xmlWriter = new XMLWriter(new FileWriter(path));
xmlWriter.write(doc);
xmlWriter.flush();
xmlWriter.close();
} catch (Exception e) {
return;
}
}
/**
* jdom解析xml
*/
public static org.jdom2.Document xmlTodDocJdom(String path){
File file = new File(path);
org.jdom2.Document doc = null;
try {
doc =new SAXBuilder().build(file);
} catch (Exception e) {
e.printStackTrace();
}
return doc;
}
public static String docToString(org.jdom2.Document doc){
String xmlStr = "";
Format format = Format.getPrettyFormat();
format.setEncoding("UTF-8");//配置xml文档的字符为gb2312,解决中文问题
XMLOutputter xmlout = new XMLOutputter(format);
ByteArrayOutputStream bo = new ByteArrayOutputStream();
try {
xmlout.output(doc,bo);
} catch (IOException e) {
e.printStackTrace();
}
xmlStr = bo.toString();
return xmlStr;
}
public static org.jdom2.Document stringTodDocJdom (String xmlStr){
org.jdom2.Document doc = null;
StringReader sr = new StringReader(xmlStr);
InputSource is = new InputSource(sr);
try {
doc =(new SAXBuilder()).build(is);
} catch (Exception e) {
e.printStackTrace();
}
return doc;
}
/**
* DOCUMENT格式化输出保存为XML
*
* @param doc JDOM的Document
* @param filePath 输出文件路径
* @throws Exception
*/
public static void doc2XML(org.jdom2.Document doc, String filePath) throws Exception{
Format format = Format.getCompactFormat();
format.setEncoding("UTF-8"); //设置XML文件的字符为UTF-8
format.setIndent(" ");//设置缩进
XMLOutputter outputter = new XMLOutputter(format);//定义输出 ,在元素后换行,每一层元素缩排四格
FileWriter writer = new FileWriter(filePath);//输出流
outputter.output(doc, writer);
writer.close();
}
/**
* jdk api解析xml
*/
public static Document xmlTodDoc(String path){
File file = new File(path);
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = null;
Document doc = null;
try {
builder = factory.newDocumentBuilder();
doc = builder.parse(file);
} catch (Exception e) {
e.printStackTrace();
}
return doc;
}
public static String xmlToString(Document doc){
String xmlStr = "";
TransformerFactory tf = TransformerFactory.newInstance();
Transformer t;
try {
t = tf.newTransformer();
ByteArrayOutputStream bos = new ByteArrayOutputStream();
t.transform(new DOMSource(doc), new StreamResult(bos));
xmlStr = bos.toString();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return xmlStr;
}
public static Document stringToXml(String xmlStr){
Document doc = null;
StringReader sr = new StringReader(xmlStr);
InputSource is = new InputSource(sr);
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder;
try {
builder = factory.newDocumentBuilder();
doc = builder.parse(is);
} catch (Exception e) {
e.printStackTrace();
}
return doc;
}
/**
* Document 保存为 XML 文件
*
* @param doc Document对象
* @param path 文件路径
*/
public static void doc2XML(Document doc, String path) {
try {
Source source = new DOMSource(doc);
Result result = new StreamResult(new File(path));
Transformer transformer = TransformerFactory.newInstance().newTransformer();
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
transformer.transform(source, result);
} catch (Exception e) {
return;
}
}
}
dom4J 解析文档
org.dom4j.Element element = doc.getRootElement();
System.out.println(element.getName());
List<org.dom4j.Element> iter = element.elements();
for (org.dom4j.Element elem : iter) {
System.out.println(elem.getName());
if(elem.getName().equals("HeadInfo")){
System.out.println(elem.attributeValue("PGMVersion"));
};
if(elem.getName().equals("PGM")){
List<org.dom4j.Element> subIter = elem.elements();
for (org.dom4j.Element el : subIter) {
System.out.println(el.getName());
System.out.println(el.attributeValue("ItemType"));
if(el.attributeValue("ItemType").equals("1")){
List<org.dom4j.Element> subEl = el.elements();
for (org.dom4j.Element e : subEl) {
System.out.println(e.getName());
}
}
}
}
}
相关文章
- XML转换_xml文件转化为excel格式
- java解析xml element_java解析XML Node与Element的区别(推荐)「建议收藏」
- c语言 自己编程解析 xml,C语言解析.XML文件
- 【java实现网址转换为二维码】「建议收藏」
- json字符串转换为实体类_java类字符串转为日期格式
- Java 环境下用 PDFBox 实现 PDF 文档转换 JPG 图片的功能
- NSData 与 NSString,Byte数组,UIImage 的相互转换详解手机开发
- struts2(三)之表单参数自动封装与参数类型自动转换详解编程语言
- MySQL导入XML文件的步骤(mysql导入xml)
- Oracle存储XML数据的解决方案(oracle存储xml)
- MySQL 逆向工程:从数据库到模型的可视化转换(mysql逆向工程)
- [代码]比较XML文件差异[cl_proxy_ui_utils=>show_xml_diff]详解编程语言
- SAP 将ITAB内表的数据转换为XML字符串 代码实例详解编程语言
- XML数据导入MSSQL:实现简便迅速(xml导入mssql)
- 轻松学习:Linux如何修改XML文件(linux修改xml)
- 使用MySQL和XML编写高效语句(mysql xml 语句)
- MySQL和XML如何处理小于符号(mysql xml小于)
- 深入了解MySQL XML数据库,优化数据存储与检索(mysql xml数据库)
- 使用MySQL处理XML文件时如何比较大小(mysql xml 大于)
- Oracle XML转换为表格形式简单几步即可实现(oracle xml转表)
- Oracle XML安装指南(oracle xml安装)
- Oracle 12 将行转换为列的操作技巧(oracle12 行转列)
- 使用PHP和XSLstylesheets转换XML文档
- PL/SQL类型格式转换
- 解析在.net中使用XSLT转换xml文档的示例详解
- C#对象与XMl文件之间的相互转换
- javascript实现日期格式转换