- 浏览: 271814 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
laitaogood:
请问,还有哪些API服务呢?比如说查看用户问答积分啊,用户发帖 ...
JavaEye-Api -
ruixinzheng:
闲聊一下
URL: http://api.iteye.com ...
JavaEye-Api -
ling520:
.....
思绪起*心间 -
ling520:
亲爱的,对不起哦~以后我一定尽量不让你等了~
今天,突然有了一种失落感 -
ling520:
小兔子想你了哈~
我很想你
所涉及到的文件列表如下:
ExcelReport.java
TemplateParser.java
ReportUtil.java
Constants.java
依赖jar包:
commons-io-1.4.jar
dom4j-1.5.jar
jaxen-1.1.jar
配置模板文件:
test_info.xls
test_info.xml
在大数据量的报表导出中,配合JMS消息队列一起使用!
(ExcelReport.java)
import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStreamWriter; import java.io.Writer; import java.sql.Timestamp; import java.util.Date; import java.util.ArrayList; import java.util.HashMap; import java.util.HashSet; import java.util.List; import org.apache.commons.io.FileUtils; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class ExcelReport { // 用于存放对模板对应的XML文件的解析 private ArrayList columnList = null; private String destpath = ""; private String dirname = ""; private int count = 0; private String actualDest = ""; private HashSet sheetSet = new HashSet(); @SuppressWarnings("unchecked") public ExcelReport(String xlstemplate, String xmltemplate, String dest,String fileFolder, String systemCode){ destpath = dest; //创建生成报表的文件夹 ReportUtil.createDir("d:/temp/report/result/", fileFolder,systemCode); dirname = xlstemplate.substring(xlstemplate.lastIndexOf("/") + 1,xlstemplate.lastIndexOf(".")); actualDest = xlstemplate.substring(0, xlstemplate.lastIndexOf("/") + 1); SAXReader reader = new SAXReader(); Document document = null; try { document = reader.read(new File(xlstemplate)); } catch (DocumentException e) { e.printStackTrace(); } List list = (ArrayList) document.selectNodes("/ss:Workbook/ss:Worksheet"); HashSet set = new HashSet(); ArrayList sheetList = new ArrayList(); for (int i = 0; i < list.size(); i++) { Element node = (Element) list.get(i); if (!set.contains(node)){sheetList.add(node);} set.add(node); } for (int j = 0; j < sheetList.size(); j++) { Element node = (Element) sheetList.get(j); String sheetname = actualDest + dirname + "/sheet" + j + ".txt"; try { FileUtils.writeStringToFile(new File(sheetname), node.asXML().toString(), "UTF-8"); } catch (IOException e) { e.printStackTrace(); } } TemplateParser parser = new TemplateParser(); // 对模板进行解析获取数据库字段和列明的关系 try { columnList = (ArrayList) parser.templateParser(xmltemplate); } catch (DocumentException e) { e.printStackTrace(); } // 将文件头写到一个文件中去 Writer writer = null ; try { writer = new OutputStreamWriter(new FileOutputStream(new File(dest)), "utf-8"); List list0 = FileUtils.readLines(new File(xlstemplate), "UTF-8"); for (int i = 0; i < list0.size(); i++) { String temp = (String) list0.get(i); if (!temp.contains("Worksheet")) { writer.write(temp + "\n"); } else break; } }catch (IOException e) { e.printStackTrace(); }finally{ if(writer!=null){ try { writer.flush(); writer.close(); } catch (IOException e) { e.printStackTrace(); } } } } /** * * @param resultList * 数据集 * @param sheet * 在模板中的第几个sheet,只有一个,则为0 * @param end * 是否是需要到处的最后一批数据 * @return * @throws IOException * @throws IOException */ @SuppressWarnings("unchecked") public boolean generateReport(List resultList, int sheet, boolean end, String head_content, String foot_content){ if(resultList.size()==0&&!end) return true; if(resultList.size()==0&&end) { Writer writer = null ; try{ writer = new OutputStreamWriter(new FileOutputStream(new File(destpath), true), "utf-8"); writer.write("</Workbook>"); }catch (IOException e) { e.printStackTrace(); }finally{ if(writer!=null){ try { writer.flush(); writer.close(); } catch (IOException e) { e.printStackTrace(); } } } return true; } boolean result = true; if (!sheetSet.contains(sheet) && count == 0) { sheetSet.add(sheet); count++; } else if (sheetSet.contains(sheet) && count != 0) { count++; } else if (!sheetSet.contains(sheet) && count != 0) { sheetSet.add(sheet); count = 0; count++; } //int sheetLength = 0; Writer writer = null ; try { writer = new OutputStreamWriter(new FileOutputStream(new File(destpath), true), "utf-8"); List list0 = FileUtils.readLines(new File(actualDest + dirname+ "/sheet" + sheet + ".txt"), "UTF-8"); int j = 0; int k = 0; int t = 0; int y = 0; ArrayList tempList = new ArrayList(); for (int i = 0; i < list0.size(); i++) { k++; t++; String temp = (String) list0.get(i); if (temp.contains("ss:ExpandedRowCount=")) { String temp1 = temp.substring(temp.indexOf("ss:ExpandedRowCount=")); String temp2 = temp1.substring(0, temp1.indexOf(" ")); temp = temp.replace(temp2, ""); } if (temp.contains("Worksheet") && temp.contains("ss:Name=")) { String temp1 = temp.substring(temp.indexOf("ss:Name=")); String temp2 = temp1.substring(temp1.indexOf("\"") + 1,temp1.lastIndexOf("\"")); String temp3 = "ss:Name=\"" + temp2 + "_" + count + "\">"; temp = temp.replace(temp1, temp3); } if (temp.contains("</Row>")){j++;} if (temp.contains("</Data>")&&y==0){ y++; temp = temp.replace("</Data>",(head_content) + "</Data>")+"\n"; } if (j < 2) writer.write(temp + "\n"); if (j == 2) { writer.write(temp + "\n"); break; } } for (int i = k; i < list0.size(); i++) { t++; String temp = (String) list0.get(i); tempList.add(temp); if (temp.contains("</Row>")) { break; } } HashMap columnMap = null; for (int i = 0; i < columnList.size(); i++) { columnMap = (HashMap) columnList.get(i); if (columnMap != null && columnMap.get("sheet").equals(String.valueOf(sheet))){break;} } for (int i = 0; i < resultList.size(); i++) { String temp = ""; HashMap map = (HashMap) resultList.get(i); temp += tempList.get(0) + "\n"; for (int g = 1; g < tempList.size() - 1; g++) { String key = Integer.toString(g - 1); Object obj = map.get(columnMap.get(key)); String type_name = "" ; if(obj!=null){ type_name = obj.getClass().getSimpleName(); }else{ type_name = "String" ; } if(type_name==null){type_name = "String" ;} String value = "" ; if(type_name.equals("String")){ value = (String)map.get(columnMap.get(key)); }else if(type_name.equals("Timestamp")){ Timestamp temp_tamp = (Timestamp)map.get(columnMap.get(key)); value = temp_tamp.toString(); } if(value==null){value="";} temp += ((String)tempList.get(g)).replace("</Data>",(value) + "</Data>") + "\n"; } temp += tempList.get(tempList.size() - 1) + "\n"; writer.write(temp); writer.flush(); } //加入尾部的信息 writer.write("<Row><Cell><Data ss:Type=\"String\">"+foot_content+"</Data></Cell></Row>"); for (int i = t; i < list0.size(); i++) { writer.write((String) list0.get(i) + "\n"); } if (end){writer.write("</Workbook>");} }catch (IOException e) { result = false; e.printStackTrace(); }finally{ if(writer!=null){ try{ writer.flush(); writer.close(); } catch (IOException e) { e.printStackTrace(); } } } return result; } /** * * 用于测试的方法(不启用) * @param args * @throws Exception */ public static void main(String[] args) throws Exception { ArrayList<HashMap> list = new ArrayList<HashMap>(); Timestamp log_time_local2 = new Timestamp(new Date().getTime()); for (int i = 0; i <= 6550; i++) { HashMap<String,Object> map = new HashMap<String,Object>(); map.put("id", "id"+i); map.put("value1", "value1:"+i); map.put("value2", "value2:"+i); map.put("value3", "value3:"+i); map.put("value4", "value4:"+i); map.put("value5", "value5:"+i); map.put("value6", log_time_local2); map.put("value7", "value7:"+i); map.put("value8", "value8:"+i); map.put("value9", "value9:"+i); map.put("value10","value10:"+i); list.add(map); } //int record_size = new Integer(Constants.RECORD_SIZE); //int max_sheet = Constants.MAX_SHEET; //int max_file = Constants.MAX_FILE; ExcelReport report = new ExcelReport("d:/temp/report/template/test_info.xls","d:/temp/report/template/test_info.xml", "d:/temp/report/result/2010-07-14/project1/testinfo-0000001.xls","2010-07-14","project1"); report.generateReport(list, 0, false, "select 1 from sysibm.sysdummy1", "select 2 from sysibm.sysdummy1"); report.generateReport(list, 0, true, "select 1 from sysibm.sysdummy1", "select 2 from sysibm.sysdummy1"); //采用追加SHEET的方式对数据进行分批处理(注意Excel 一个sheet页最大的数据量在65535条数据,超过后不能打开) //report.generateReport(list, 0, true); //report.generateReport(list, 0, false); //report.generateReport(list, 0, false); //report.generateReport(list, 0, false); //report.generateReport(list, 0, false); //report.generateReport(list2, 1, false); //report.generateReport(list2, 1, false); //report.generateReport(list2, 1, false); //report.generateReport(list2, 1, false); //report.generateReport(list2, 1, true); //System.out.println(new Integer(Constants.RECORD_SIZE) * new Integer(Constants.MAX_SHEET)); //文件目录 d:/temp/report/ (result,template) System.out.println("Complete!"); } }
TemplateParser.java
import java.io.File; import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; import java.util.List; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class TemplateParser { public List templateParser(String template) throws DocumentException{ SAXReader reader = new SAXReader(); List resultList =new ArrayList(); Document document = reader.read(new File(template)); List list0 = document.selectNodes("/report/report_content"); for(int i=0;i<list0.size();i++){ Element value0=(Element)list0.get(i); String tempValue=value0.attributeValue("sheet"); List list = document.selectNodes("/report/report_content[@sheet="+tempValue+"]/property"); Iterator it = list.iterator(); String row=""; HashMap map=new HashMap(); map.put("sheet", tempValue); while (it.hasNext()) { Element value = (Element) it.next(); map.put(value.attributeValue("column"), value.attributeValue("name")); row=value.attributeValue("row"); } map.put("row", row); resultList.add(map); } return resultList; } /** * @param args * @throws DocumentException */ public static void main(String[] args) throws DocumentException { TemplateParser p=new TemplateParser(); List list1 = p.templateParser("d:/temp/report/template/client_info.xml"); //System.out.println(list1); } }
ReportUtil.java
import java.io.File; import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class ReportUtil { private static File m_root; // 记录要删除的路径 private static ArrayList m_dirs;// 删除的路径下的所有文件和文件夹 /** * 创建文件夹 */ public static void createDir(String path , String folder1,String folder2){ createDir(path+folder1); createDir(path+folder1+File.separator + folder2); } /** * 创建文件夹 */ public static void createDir(String path) { File dir = new File(path); if (!dir.exists()) { System.out.println("dir not exist and need create :" + path); dir.mkdir(); } } /** * 删除文件夹方法 */ public static void deleteDirs(String path) { deleteDirs(new File(path)); } /** * 删除文件夹方法 * dir * 要删除的文件夹路径(java.io.File类型) */ public static void deleteDirs(java.io.File dir) { try { m_root = dir; m_dirs = new ArrayList(); if (!m_root.isDirectory()) { // 判断输入的是否为路径 System.out.println(m_root.toString() + " 不是路径"); } else { // 输出m_dirs中记录的值 // for(int i=0 ; i<m_dirs.size() ; i++){ // System.out.println(((File)m_dirs.get(i)).toString()); // } m_dirs.add(m_root); visitAll(m_root); // 获取指定路径下的所有文件已经文件夹(递归调用) rootDelete(); // 删除list中的所有文件(倒叙循环删除) } } catch (Exception ex) { System.out.println("error in deleteDirs : " + ex.getMessage()); } } /** * 删除文件或文件夹 注意:使用倒叙删除,先删除文件,然后删除空文件夹 */ private static void rootDelete() { try { if (m_dirs != null) { // 使用倒叙循环删除(先删除文件,再删除文件夹) for (int i = m_dirs.size() - 1; i >= 0; i--) { File f = (File) m_dirs.remove(i);// 获取之后删除list中的数据 // 删除数据 if (!f.delete()) { System.out.println("文件路径:" + f.toString() + " 不存在"); } } } else { System.out.println("获取文件list列表(m_dirs)为空"); } } catch (Exception ex) { System.out.println("error in rootDelete : " + ex.getMessage()); } } /** * 获取所有文件和文件夹,存储在m_dirs中 注意:递归调用 * * @param tempRoot * 文件路径 */ private static void visitAll(File tempRoot) { try { // 获取指定路径下的所有文件 File[] dirs = tempRoot.listFiles(); if (dirs != null) { // 将文件数组转换成List对象 List dirslist = Arrays.asList(dirs); // 将dirslist完全添加到m_dirs中 m_dirs.addAll(dirslist); // 递归调用 for (int i = 0; i < dirslist.size(); i++) { visitAll((File) dirslist.get(i)); } } } catch (Exception ex) { System.out.println("error in visitAll : " + ex.getMessage()); } } }
Constants.java
public class Constants { /** * 报表的sheet页信息 */ public final static String REPORT_QUEUE_SHEET_NUMBER = "sheet_number"; /** * 报表的多文件信息 */ public final static String REPORT_QUEUE_MULTI_FILE = "multi_file"; /** * 报表任务的申请时间 */ public final static String REPORT_QUEUE_APPLY_TIME = "apply_time"; /** * * 从配置文件查找,如果找不到,返回null * * @param key * @return */ /** * 生成的报表每个sheet页放置的数量 */ public static String RECORD_SIZE;// /** * 每个报表最多可生成sheet页的数量 */ public static int MAX_SHEET;// /** * 每个报表任务最多可生成的报表数量 */ public static int MAX_FILE;// /** * 可写入数据的报表文件大小的最大值<最好小于9M=9437184> */ public static int REPORT_FILE_READ_SIZE;// }
test_info.xls
<?xml version="1.0"?> <?mso-application progid="Excel.Sheet"?> <Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:dt="uuid:C2F41010-65B3-11d1-A29F-00AA00C14882" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:html="http://www.w3.org/TR/REC-html40"> <DocumentProperties xmlns="urn:schemas-microsoft-com:office:office"> <LastAuthor>ago</LastAuthor> <Created>2010-01-14T12:08:11Z</Created> <LastSaved>2010-03-12T09:30:16Z</LastSaved> <Version>11.6568</Version> </DocumentProperties> <CustomDocumentProperties xmlns="urn:schemas-microsoft-com:office:office"> <sflag dt:dt="string">1268365527</sflag> </CustomDocumentProperties> <ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel"> <WindowHeight>9150</WindowHeight> <WindowWidth>14940</WindowWidth> <WindowTopX>360</WindowTopX> <WindowTopY>270</WindowTopY> <AcceptLabelsInFormulas/> <ProtectStructure>False</ProtectStructure> <ProtectWindows>False</ProtectWindows> </ExcelWorkbook> <Styles> <Style ss:ID="Default" ss:Name="Normal"> <Alignment ss:Vertical="Bottom"/> <Borders/> <Font ss:FontName="Helv" x:Family="Swiss"/> <Interior/> <NumberFormat/> <Protection/> </Style> <Style ss:ID="s21" ss:Name="常规_sheet"> <Alignment ss:Vertical="Center"/> <Borders/> <Font ss:FontName="FrutigerNext LT Regular" x:Family="Swiss" ss:Size="12"/> <Interior/> <NumberFormat/> <Protection/> </Style> <Style ss:ID="s23" ss:Parent="s21"> <Font ss:FontName="FrutigerNext LT Regular" x:Family="Swiss" ss:Size="9"/> </Style> <Style ss:ID="s24" ss:Parent="s21"> <Font ss:FontName="FrutigerNext LT Regular" x:Family="Swiss" ss:Size="9"/> <NumberFormat ss:Format="@"/> </Style> <Style ss:ID="s25"> <Alignment ss:Vertical="Center"/> <Borders> <Border ss:Position="Bottom" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Left" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Right" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Top" ss:LineStyle="Continuous" ss:Weight="1"/> </Borders> <Font ss:FontName="宋体" x:CharSet="134" ss:Size="9"/> </Style> <Style ss:ID="s26"> <Font ss:FontName="FrutigerNext LT Regular" x:Family="Swiss" ss:Size="9"/> <NumberFormat ss:Format="@"/> </Style> <Style ss:ID="s27"> <Alignment ss:Horizontal="Center" ss:Vertical="Center" ss:WrapText="1"/> <Borders> <Border ss:Position="Bottom" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Left" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Right" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Top" ss:LineStyle="Continuous" ss:Weight="1"/> </Borders> <Font ss:FontName="宋体 (serif)" x:CharSet="134" ss:Size="9" ss:Bold="1"/> <Interior ss:Color="#C0C0C0" ss:Pattern="Solid"/> </Style> <Style ss:ID="s28"> <Alignment ss:Horizontal="Center" ss:Vertical="Center"/> <Borders> <Border ss:Position="Bottom" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Left" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Right" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Top" ss:LineStyle="Continuous" ss:Weight="1"/> </Borders> <Font ss:FontName="FrutigerNext LT Regular" x:Family="Swiss" ss:Size="9"/> <Interior ss:Color="#FFFF99" ss:Pattern="Solid"/> </Style> <Style ss:ID="s29"> <Alignment ss:Horizontal="Center" ss:Vertical="Center"/> <Borders> <Border ss:Position="Bottom" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Left" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Right" ss:LineStyle="Continuous" ss:Weight="1"/> <Border ss:Position="Top" ss:LineStyle="Continuous" ss:Weight="1"/> </Borders> <Font ss:FontName="宋体" x:CharSet="134" ss:Size="9" ss:Bold="1"/> <Interior ss:Color="#C0C0C0" ss:Pattern="Solid"/> <Protection ss:Protected="0"/> </Style> </Styles> <Worksheet ss:Name="Sheet1"> <Table ss:ExpandedColumnCount="11" ss:ExpandedRowCount="4" x:FullColumns="1" x:FullRows="1" ss:StyleID="s23" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="12"> <Column ss:StyleID="s23" ss:AutoFitWidth="0" ss:Width="60" ss:Span="5"/> <Column ss:Index="7" ss:StyleID="s23" ss:AutoFitWidth="0" ss:Width="87.75"/> <Column ss:StyleID="s23" ss:AutoFitWidth="0" ss:Width="108.75"/> <Column ss:StyleID="s23" ss:AutoFitWidth="0" ss:Width="60"/> <Column ss:StyleID="s24" ss:AutoFitWidth="0" ss:Width="127.5"/> <Column ss:StyleID="s24" ss:AutoFitWidth="0" ss:Width="141"/> <Row ss:AutoFitHeight="0" ss:Height="15.75"> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s25"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s26"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s26"><Data ss:Type="String"> </Data></Cell> </Row> <Row ss:AutoFitHeight="0" ss:Height="15"> <Cell ss:StyleID="s27"><Data ss:Type="String">id</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值1</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值2</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值3</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值4</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值5</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值6</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值7</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值8</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值9</Data></Cell> <Cell ss:StyleID="s27"><Data ss:Type="String">值10</Data></Cell> </Row> <Row ss:AutoFitHeight="0" ss:Height="14.25"> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s28"><Data ss:Type="String"> </Data></Cell> </Row> <Row ss:AutoFitHeight="0"> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"/> <Cell ss:StyleID="s29"/> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> <Cell ss:StyleID="s29"><Data ss:Type="String"> </Data></Cell> </Row> </Table> <WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel"> <PageSetup> <Header x:Data="&L&C&F&R&"宋体,常规"文档密级:"/> <Footer x:Data="&L&D&&R第&P页,共&N页"/> </PageSetup> <Unsynced/> <Print> <ValidPrinterInfo/> <PaperSizeIndex>9</PaperSizeIndex> <HorizontalResolution>600</HorizontalResolution> <VerticalResolution>600</VerticalResolution> </Print> <Selected/> <Panes> <Pane> <Number>3</Number> <ActiveRow>15</ActiveRow> <ActiveCol>9</ActiveCol> </Pane> </Panes> <ProtectObjects>False</ProtectObjects> <ProtectScenarios>False</ProtectScenarios> </WorksheetOptions> </Worksheet> </Workbook>
test_info.xml
<?xml version="1.0" encoding="UTF-8"?> <report templet="test_info.xls"> <!--表头部分 start_row为起始行号 row_height为表头的总行数 column-width为表头的列宽 --> <report_header start_row="0" row_height="2" column-width="4"> <!-- name对应sql语句中查询的列名 column为报表模板中的列号 row为报表模板中的列号 --> <property name="1" column="0" row="0"/> </report_header> <!--表中部分 start_row为起始行号 start_column为起始列号 row_height为循环行的高度 column-width为表中的列宽(即循环行的最后一列的位置) --> <report_content sheet="0" start_row="2" start_column="0" row_height="1" column-width="17"> <property name="id" column="0" row="2"/> <property name="value1" column="1" row="2"/> <property name="value2" column="2" row="2"/> <property name="value3" column="3" row="2"/> <property name="value4" column="4" row="2"/> <property name="value5" column="5" row="2"/> <property name="value6" column="6" row="2"/> <property name="value7" column="7" row="2"/> <property name="value8" column="8" row="2"/> <property name="value9" column="9" row="2"/> <property name="value10" column="10" row="2"/> </report_content> <!--表头部分 start_row为起始行号 row_height为表尾的总行数 column-width为表尾的列宽 --> <report_footer start_row="3" row_height="1" column-width="17"> <property name="1" column="0" row="3"/> </report_footer> <!----> </report>
至此完毕!
发表评论
-
《深入浅出 Java Concurrency》目录
2011-07-20 14:32 849J.U.C 整体认识 原子操作 part 1 ... -
HashMap中取得key值和value值(另:HashMap会自己排序的问题)
2010-09-16 08:12 2131// 第一种:通过Map.keySet遍历key和value ... -
关于QQ等级需要小时数引发的算法联想
2010-08-08 12:18 739这是一个在游戏中比较通用的递增数据,如下: //1 20 ... -
AJAX+jsp无刷新验证码实例
2010-08-08 12:15 993我们在做验证码的时候往往由于要反,验证有时故意加入多的干扰因素 ... -
Gerry版网页爬虫V0.01(Java语言版本)
2010-06-23 16:26 932import java.io.ByteArrayOutputS ... -
VC下CHttpFile.ReadString 中文读取乱码的编码方法
2010-06-21 15:39 3434//UTF-8 to GB2312 CString WebP ...
相关推荐
NULL 博文链接:https://ago520.iteye.com/blog/814571
NULL 博文链接:https://ago520.iteye.com/blog/754087
格里 一种基于gerrymandering的分析工具,用于基于围绕公平性的众多启发式方法来重绘区域线。 特征 美国的可缩放,可缩放地图,可显示多个州。 全面细分州,地区和辖区级别的人口统计数据和选举数据。...
嗨,您在Gerry Aballa的Git上 :waving_hand: :laptop: :mobile_phone: 我是一名技术狂,在创建和使用技术来提升人们,企业和社区建设方面感到满意。我的技术栈更多关于我的员工 :smiling_face_with_sunglasses: ...
gem install gerry-0.0.1.gem 例子 获得全球能力 client = Gerry . new ( 'https://review' ) client . account_capabilities => { "queryLimit" => { "min" => 0 , "max" => 250 } } 列出项目 client = Gerry . ...
在本案例中,我们有一个名为"图片上传组件v1.0"的自定义组件,设计用于提供可重用的图片上传解决方案。下面将详细讨论这个组件可能涉及的技术点、实现原理以及其在实际开发中的应用场景。 1. **组件化思想**:组件...
在Android应用开发中,有时我们需要根据特定需求定制用户界面,比如在输入数字的场景下,可能希望禁用系统默认的软键盘,转而显示一个自定义的数字键盘。标题"自定义数字键盘"和描述"在edittext点击后禁止弹出自带软...
至于`js`目录,它包含了SWFUpload的JavaScript库文件以及可能的自定义脚本。这些脚本负责初始化SWFUpload对象,设置上传参数,处理文件选择、上传进度和错误事件等。 集成SWFUpload到Java环境中,开发者需要确保...
IK (Intelligent Chinese Analyzer) 分词器是一款流行的开源中文分词组件,它具有丰富的分词算法和优秀的性能。IK 分词器支持自定义扩展词典,可以根据实际需求添加或修改词汇,提高分词的准确性。此外,它还提供了...
4. `jquery-easing.1.2.js` 和 `jquery-easing.1.2.pack.js`:这些是jQuery Easing插件,用于添加自定义的缓动函数,使得动画过渡更加平滑自然。 5. `jquery-easing-compatibility.1.2.js` 和 `jquery-easing-...
压缩包内的文件包含了IK分词插件运行所需的各个组件: 1. **httpclient-4.5.2.jar**:这是Apache HttpClient库的一个版本,用于HTTP客户端通信,插件可能依赖于它来与ES服务器交互。 2. **httpcore-4.4.4.jar**:...
每个页面都有一个唯一的URL,页面组件可以包含文本、图像、链接等基本元素,也可以包含自定义的复杂组件。 2. **组件服务**:Tapestry 提供了一种服务容器,允许开发者创建和管理可重用的服务。这些服务可以在组件...
【标题】"gerry0002.hithub.io" 是一个个人博客或网站的名称,通常在GitHub Pages上托管。这个平台允许用户免费发布和分享他们的网页内容,尤其适合技术爱好者展示项目、分享代码和撰写技术文章。 【描述】描述中的...
HMA,全称Hull Moving Average,是由Gerry Hull开发的一种移动平均线改进算法。传统的移动平均线可能对价格变化反应较慢,而HMA的优势在于它能更快速地反映出市场的最新动向,减少了延迟,从而提高交易决策的时效性...
- Gerry Batista - Doug Bridges - Sandra Cheevers - Ralf Durben - Ari Fyhr - Joel Goodman - Scott Gossett - Lex de Haan - Tony Holbrook - Heike Hundt - Christine Jeal - Dominique Jeunot - ...
针对这个问题,Gerry Sweeney提供了一种自定义实现方案,即通过派生出一个新的类CXTPPropertyPageEx来解决这一问题。具体做法是在项目的stdafx.h或类似的预编译头文件中添加以下代码: ```cpp class ...
源文件损坏,不用下载.直接参照以下内容: 安装环境:Fedora ...4.在/home/gerry下创建tftpboot目录,并且修改权限 mkdir tftpboot chmod 777 tftpboot/ 5.启动tftp服务器 service xinetd restart
大家好! 我叫Gerald Sanga,我是一名全职开发人员。 我来自坦桑尼亚,住在达累斯萨拉姆,目前是自由职业者。 :wrench: 技术与工具 :chart_increasing: GitHub统计
产品负责人-Gerry Scrum大师-Mike / Andrew 开发工程师-布伦丹,安德鲁,丹尼尔 用户界面设计-迈克 用户体验和可用性设计-珍妮 领域专家-埃斯特 用户测试员-Liza,Jody 前端应用 安装: npm install和bower ...
- **格里·凯恩教授**(Professor Gerry D. Cain),英国威斯敏斯特大学电子与制造系统工程学院。 - **科林·考万教授**(Professor Colin Cowan),北爱尔兰贝尔法斯特女王大学电子与电气工程系。 - **罗伊·戴维斯...