zoukankan      html  css  js  c++  java
  • JAVA-POI

    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    
    import org.apache.poi.hssf.usermodel.HSSFCell;
    import org.apache.poi.hssf.usermodel.HSSFCellStyle;
    import org.apache.poi.hssf.usermodel.HSSFFont;
    import org.apache.poi.hssf.usermodel.HSSFRow;
    import org.apache.poi.hssf.usermodel.HSSFSheet;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.hssf.util.Region;
    import org.apache.poi.ss.usermodel.Font;
    import org.apache.poi.ss.util.CellRangeAddress;
    import org.hibernate.SQLQuery;
    import org.hibernate.transform.Transformers;
    import org.jboss.seam.annotations.Name;
    import org.jboss.seam.annotations.remoting.WebRemote;
    
    import com.sunsheen.jfids.system.base.composite.data.query.QueryParameterImpl;
    import com.sunsheen.jfids.system.database.DBSession;
    import com.sunsheen.jfids.util.DataBaseUtil;
    
    public class SalaryPoi {
        
        @SuppressWarnings("deprecation")
        public String getToExcel(){
            ......省略数据源获取
            // 返回表单结果集
            List list = query.list();
            int size = list.size();
            System.out.println("+++++++++++++" + size);
        
            //初始化POI
            //创建工作簿---->XSSF代表10版的Excel(HSSF是07版前的Excel)
            HSSFWorkbook wb = new  HSSFWorkbook();
            
            //工作表
            HSSFSheet sheet = wb.createSheet("淞幸科技");
            
            //标头行,代表第一行
            HSSFRow head=sheet.createRow(0);
            HSSFCell hssfCell=head.createCell(0);
            
            hssfCell.setCellValue("成都淞幸科技有限责任公司"+date.substring(0,4)+"年"+
            date.substring(date.length()-2,date.length())+"月工资表");
            head.setHeightInPoints(70);
            
            //合并第一行的单元格
            CellRangeAddress address=new CellRangeAddress(0,0,0,26);
            sheet.addMergedRegion(address);
            
            //创建字体与风格
            HSSFCellStyle cellStyle = wb.createCellStyle();//生成表头格样式
            HSSFFont hssfFont = wb.createFont();//创建字体
            hssfFont.setFontHeightInPoints((short)12);//字体大小
            hssfFont.setBoldweight(Font.BOLDWEIGHT_BOLD);//粗体
            cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平居中
            cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中
            cellStyle.setFont(hssfFont);
            hssfCell.setCellStyle(cellStyle);
            
            //修饰风格2
            HSSFCellStyle cellStyle2 = wb.createCellStyle();//生成表头格样式
            cellStyle2.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平居中
            cellStyle2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中
            
            
            HSSFRow header=sheet.createRow(1);
            //创建单元格,0代表第一行第一列
            String[] heards ={"序号","部门名称","工号","姓名","银行卡号","定级工资","岗位工资","基础
                    ,"实发工资总额"......}; 
            for(int i =0;i<heards.length;i++){
                HSSFCell hssfCell1=header.createCell(i);
                hssfCell1.setCellStyle(cellStyle2);
                hssfCell1.setCellValue(heards[i]);
            }
            //设置列的宽度
    //        getPhysicalNumberOfCells()代表这行有多少包含数据的列
            for(int i=0;i<header.getPhysicalNumberOfCells();i++){
            //POI设置列宽度时比较特殊,它的基本单位是1/255个字符大小,
            //因此我们要想让列能够盛的下20个字符的话,就需要用255*20
            sheet.setColumnWidth(i, 255*15);
            }
            //设置行高,行高的单位就是像素,因此30就是30像素的意思
            header.setHeightInPoints(30);
            int k =2;
    //        
            for(int i=0;i<size;i++){
    //            //创建多行数据
                HSSFRow headers=sheet.createRow(k++);
    //            //拿出所有查询出的一条list(list(Map<>))信息
                Map<String, Object> map = (Map<String, Object>) list.get(i);
                System.out.println(map);
                
                String[] context ={你要写入的数据};
                for(int j=0;j<context.length;j++){
                    HSSFCell hssfCell2=headers.createCell(j);
                    hssfCell2.setCellStyle(cellStyle2);
                    hssfCell2.setCellValue(context[j]);
                }
            }
            
            // 合并相同列中的数据
            // 处理相同的数据合并单元格
            if(sheet.getLastRowNum()>2){//获取最后一行行标,比行数小  满足合并的条件,2是数据行的开始,0 1 行为表头
                HSSFRow row_1 = sheet.getRow(2);
                HSSFCell cell_1 = row_1.getCell(1);
                
                String departname = cell_1.getStringCellValue();
                
                for(int i=3;i<=sheet.getLastRowNum();i++){
                    //除第一个外,循环将内容相同的单元格设为"",这里体现出为什么原数据要有序!
                    HSSFRow rows = sheet.getRow(i);
                    //此处表示对单元格进行内容相同合并处理,我这里获取的是每行的第2列进行对比,要多列对比的,这里自行增加
                    HSSFCell cells_1 = rows.getCell(1);
                    //这里值相同则设置位空,方便之后的合并
                    if(departname.equals(cells_1.getStringCellValue())){
                        cells_1.setCellValue("");
                    }else{
                        departname = cells_1.getStringCellValue();
                    }
                }        
            }
            int sk;
            if(sheet.getLastRowNum()>2){//将为空的单元格与之前不为空的合并
                sk=2;                
                for(int i=3;i<=sheet.getLastRowNum();i++){
                    HSSFRow rows = sheet.getRow(i);
                    HSSFCell cell_0 = rows.getCell(1);
                    if(cell_0.getStringCellValue() == ""){//如果为空但还没对比到最后一行,继续循环
                        if(i==sheet.getLastRowNum()){
                            sheet.addMergedRegion(new CellRangeAddress(sk, i, 1, 1));//如果已经对比到最后一行,开始合并
                        }                                        
                    }else{
                        if(sk != i-1){//不为空且i-1不为sk则合并
                            sheet.addMergedRegion(new CellRangeAddress(sk, i-1, 1, 1));//起始行号,终止行号, 起始列号,终止列号
                        }
                        sk =i;
                    }
                }
            }
            //上面设置好了内容,我们当然是要输出到某个文件的,输出就需要有输出流
            FileOutputStream fos;
            try {
                fos = new FileOutputStream("d:/2010.xls");
                //向指定文件写入内容
                wb.write(fos);
                fos.close();
                return "导出Excel已完成!";
                
            } catch (FileNotFoundException e) {
                // TODO 自动生成的 catch 块
                e.printStackTrace();
            } catch (IOException e) {
                // TODO 自动生成的 catch 块
                e.printStackTrace();
            }
            
            return "导出Excel失败!";
        }
    }
  • 相关阅读:
    索引访问中的access和filter
    分页SQL走全表扫描导致TEMP耗尽
    多表关联的分页SQL经典案例
    分页技术COUNT STOPKEY和SORT ORDER BY
    FILTER再来一例
    错误的选择了HASH JOIN!
    dojo加载树报错
    dojo中获取表格中某一行的某个值
    dojo处理删除操作报错
    分页语句优化
  • 原文地址:https://www.cnblogs.com/wanchen-chen/p/12934091.html
Copyright © 2011-2022 走看看