日期:2014-05-20 浏览次数:20992 次
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(); } } }