日期:2014-05-20 浏览次数:21162 次
Document document = DocumentHelper.createDocument();
Element root = document.addElement("response");
while(rs.next()){
String id= rs.getString(0); //字段a
String counlom= rs.getString(1); //字段b
String catolg = rs.getString(2); //字段c
Element catolgEl = ((Element)document.selectSingleNode("//response/catolg[@name='"+catolg+"']"));
if(catolgEl==null){
catolgEl = root.addElement("catolg").addAttribute("name", catolg);
}
catolgEl.addElement("layer").addAttribute("id", id).addAttribute("counlom", counlom);
}
System.out.println(document.asXML());
------解决方案--------------------
这个不是例子,而是根据楼主要求写的。
楼主可以运行改下,只要把取数据那段换成你从数据库取就可以了。
用的就是dom4j
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
public class TestXML {
class Data {
public Data() {
}
String catolg;
String id;
String counlom;
}
public static void main(String[] args) {
new TestXML().output("D:\\response.xml");
}
public void output(String fileName) {
String charset = "UTF-8";
Document doc = DocumentHelper.createDocument();
Element response = doc.addElement("response"); // 根元素 response
doc.setRootElement(response);
List<String> list = new ArrayList<String>();
list.add("a1 b1 3");
list.add("a2 b2 1");
list.add("a3 b3 2");
list.add("a4 b4 1");
list.add("a6 b6 1");
list.add("a7 b7 2");
list.add("a8 b8 2");
list.add("a9 b9 1");
list.add("a10 b10 3");
//排序 保证 catolg name="1" 然后 "2" "3"
Map<String, ArrayList<Data>> sortedMap = new TreeMap<String, ArrayList<Data>>();
for (String line : list) {
String arr[] = line.split(" ");
Data d = new Data();
d.catolg = arr[2];
d.id = arr[0];
d.counlom = arr[1];
ArrayList<Data> l = sortedMap.get(d.catolg);
if (l == null) {
l = new ArrayList<Data>();
sortedMap.put(d.catolg, l);
}
l.add(d);
}
Map<String, Element> nameMap = new TreeMap<String, Element>();
for (ArrayList<Data> datas : sortedMap.values()) {
for (Data d : datas) {
String catolg = d.catolg;
String id = d.id;
String counlom = d.counlom;
Element catolgElement = nameMap.get(catolg);
if (catolgElement == null) {
catolgElement = response.addElement("catolg");
catolgElement.addAttribute("name", catolg);
nameMap.put(catolg, catolgElement);
}
Element layer = catolgElement.addElement("layer");
layer.addAttribute("id", id);
layer.addAttribute("counlom", counlom);
}
}
OutputFormat format = OutputFormat.createPrettyPrint(); // 设置XML文档输出格式
format.setEncoding(charset); // 设置XML文档的编码类型
format.setSuppressDeclaration(true);
format.setIndent(true); // 设置是否缩进
format.setIndent("\t"); // 以空格方式实现缩进
format.setNewlines(true); // 设置是否换行
// format.setExpandEmptyElements(true); //设置空元素是头和尾都写
try {
XMLWriter xmlWriter = new XMLWriter(new OutputStreamWriter(
new FileOutputStream(fileName), charset), format);
xmlWriter.write(response);
xmlWriter.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}