xml 导出

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.jdom.output.Format;
import org.jdom.output.XMLOutputter;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

public class ParseXML {

/**
*
* @param infomation 资料信息
* @return 资料文件名称 ,资料文件路径
* @throws FileNotFoundException
*/
@SuppressWarnings("unchecked")
public Map<String, String> infomationExport(List<Map<String, String>> infomation) {
//创建根节点
org.jdom.Element root = new org.jdom.Element("infomationList");

//创建doc解析对象
org.jdom.Document document = new org.jdom.Document(root);
//迭代所有资料信息
for (Iterator iterator = infomation.iterator(); iterator.hasNext();) {
Map<String, String> map = (Map<String, String>) iterator.next();
org.jdom.Element elements = new org.jdom.Element("infomation");
//迭代第一行资料信息
for (Iterator iterator2 = map.entrySet().iterator(); iterator2.hasNext();) {
Map.Entry<String, String> rowMap = (Map.Entry<String, String>) iterator2.next();
if(null == rowMap.getKey())
{
elements.addContent( new org.jdom.Element("templateTag").setText(rowMap.getValue()));
}
else{
elements.addContent( new org.jdom.Element(rowMap.getKey()).setText(rowMap.getValue()));
}
}
root.addContent(elements);
}
//xml输出解析器
XMLOutputter output = new XMLOutputter(Format.getPrettyFormat());
//导出文件模板
File file = new File(“/templateXml.xml”);
OutputStream outStream;
try {
outStream = new FileOutputStream(file);
output.output(document, outStream);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
//存储文件名称,文件路径的容器
Map<String,String> fileMap = new HashMap<String,String>();
fileMap.put(file.getName(), file.getAbsolutePath());
return fileMap;
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MXGraph是一款强大的图形编辑库,可以用于创建各种类型的图表和图形。它支持在浏览器中渲染和编辑图表,并提供了多种导出选项,包括将图表导出XML格式。 要将MXGraph图表导出为HTML代码,需要先将图表数据转换为XML格式,并使用XML解析器将其解析为JavaScript对象。然后,使用JavaScript代码将这些对象转换为HTML代码。 以下是MXGraph XML导出HTML代码的完整实现: ```javascript // 获取mxGraph实例 var graph = new mxGraph(container); // 将图表数据转换为XML格式 var encoder = new mxCodec(); var node = encoder.encode(graph.getModel()); // 使用XML解析器将XML转换为JavaScript对象 var xml = mxUtils.getXml(node); var doc = mxUtils.parseXml(xml); var root = doc.documentElement; // 定义转换器函数,将JavaScript对象转换为HTML代码 function convertNode(node) { var html = ''; // 处理节点属性 if (node.nodeType == 1) { var attributes = node.attributes; if (attributes) { for (var i = 0; i < attributes.length; i++) { var attribute = attributes.item(i); html += ' ' + attribute.nodeName + '="' + attribute.nodeValue + '"'; } } } // 处理节点类型 switch (node.nodeType) { case 1: // 元素节点 html += '>'; var children = node.childNodes; if (children) { for (var i = 0; i < children.length; i++) { html += convertNode(children.item(i)); } } html += '</' + node.nodeName + '>'; break; case 3: // 文本节点 html += node.nodeValue; break; } return html; } // 将JavaScript对象转换为HTML代码 var html = convertNode(root); // 显示HTML代码 console.log(html); ``` 此代码将MXGraph图表转换为HTML代码,并将其输出到控制台。您可以根据需要将其修改为将HTML代码显示在HTML页面中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值