MyException - 我的异常网
当前位置:我的异常网» 报表 » Java 生成 Excel表格

Java 生成 Excel表格

www.MyException.Cn  网友分享于:2013-09-16  浏览:40次
Java 生成 Excel报表
JAVA生成EXCEL,下面介绍POI 和JXL 生成报表的2种方式。
1.jxl 生成报表

Java代码 
package excel; 
 
import java.io.FileOutputStream; 
import java.io.OutputStream; 
import java.text.SimpleDateFormat; 
import java.util.Date; 
 
import jxl.Workbook; 
import jxl.format.Alignment; 
import jxl.format.Border; 
import jxl.format.BorderLineStyle; 
import jxl.format.CellFormat; 
import jxl.write.Label; 
import jxl.write.WritableCellFormat; 
import jxl.write.WritableFont; 
import jxl.write.WritableSheet; 
import jxl.write.WritableWorkbook; 
/***********************************************************************   
*   
*   @copyright       Copyright: 2012     
*   @creator         sinbong.com
***********************************************************************/ 
public class jxlCreate { 
 
    /**
     * @param args
     */ 
    public static void main(String[] args) { 
         // 准备设置excel工作表的标题    
        String[] title = {"编号","产品名称","产品价格","产品数量","生产日期","产地","是否出口"};    
        try {    
            // 获得开始时间    
            long start = System.currentTimeMillis();    
            // 输出的excel的路径    
            String filePath = "c:\\test.xls";    
            // 创建Excel工作薄    
            WritableWorkbook wwb;    
            // 新建立一个jxl文件,即在C盘下生成test.xls    
            OutputStream os = new FileOutputStream(filePath);    
            wwb=Workbook.createWorkbook(os);     
            // 添加第一个工作表并设置第一个Sheet的名字    
            WritableSheet sheet = wwb.createSheet("产品清单", 0);    
            Label label;    
            for(int i=0;i<title.length;i++){    
                // Label(x,y,z)其中x代表单元格的第x+1列,第y+1行, 单元格的内容是y    
                // 在Label对象的子对象中指明单元格的位置和内容    
                label = new Label(i,0,title[i]);    
                // 将定义好的单元格添加到工作表中    
                sheet.addCell(label);    
            }    
            // 下面是填充数据    
            /*   
             * 保存数字到单元格,需要使用jxl.write.Number  
             * 必须使用其完整路径,否则会出现错误  
             * */   
            // 填充产品编号    
            jxl.write.Number number = new jxl.write.Number(0,1,20071001);    
            sheet.addCell(number);    
            // 填充产品名称    
            label = new Label(1,1,"金鸽瓜子");    
            sheet.addCell(label);    
            /*  
             * 定义对于显示金额的公共格式  
             * jxl会自动实现四舍五入  
             * 例如 2.456会被格式化为2.46,2.454会被格式化为2.45  
             * */   
            jxl.write.NumberFormat nf = new jxl.write.NumberFormat("#.##");    
            jxl.write.WritableCellFormat wcf = new jxl.write.WritableCellFormat(nf);    
            // 填充产品价格    
            jxl.write.Number nb = new jxl.write.Number(2,1,2.45,wcf);    
            sheet.addCell(nb);    
            // 填充产品数量    
            jxl.write.Number numb = new jxl.write.Number(3,1,200);    
            sheet.addCell(numb);    
            /*  
             * 定义显示日期的公共格式  
             * 如:yyyy-MM-dd hh:mm  
             * */   
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");    
            String newdate = sdf.format(new Date());    
            // 填充出产日期    
            label = new Label(4,1,newdate);    
            sheet.addCell(label);    
            // 填充产地    
            label = new Label(5,1,"陕西西安");    
            sheet.addCell(label);    
            /*  
             * 显示布尔值  
             * */   
            jxl.write.Boolean bool = new jxl.write.Boolean(6,1,true);    
            sheet.addCell(bool);    
            /*  
             * 合并单元格  
             * 通过writablesheet.mergeCells(int x,int y,int m,int n);来实现的  
             * 表示将从第x+1列,y+1行到m+1列,n+1行合并  
             *   
             * */   
            sheet.mergeCells(0,3,2,3);    
            label = new Label(0,3,"合并了三个单元格");    
            sheet.addCell(label);    
            /*  
             *   
             * 定义公共字体格式  
             * 通过获取一个字体的样式来作为模板  
             * 首先通过web.getSheet(0)获得第一个sheet  
             * 然后取得第一个sheet的第二列,第一行也就是"产品名称"的字体   
             * */   
            CellFormat cf = wwb.getSheet(0).getCell(1, 0).getCellFormat();    
            WritableCellFormat wc = new WritableCellFormat();    
            // 设置居中    
            wc.setAlignment(Alignment.CENTRE);    
            // 设置边框线    
            wc.setBorder(Border.ALL, BorderLineStyle.THIN);    
            // 设置单元格的背景颜色    
            wc.setBackground(jxl.format.Colour.RED);    
            label = new Label(1,5,"字体",wc);    
            sheet.addCell(label);    
   
            // 设置字体    
            jxl.write.WritableFont wfont = new jxl.write.WritableFont(WritableFont.createFont("隶书"),20);    
            WritableCellFormat font = new WritableCellFormat(wfont);    
            label = new Label(2,6,"隶书",font);    
            sheet.addCell(label);    
                
            // 写入数据    
            wwb.write();    
            // 关闭文件    
            wwb.close();    
            long end = System.currentTimeMillis();    
            System.out.println("----完成该操作共用的时间是:"+(end-start)/1000);    
        } catch (Exception e) {    
            System.out.println("---出现异常---");    
            e.printStackTrace();    
        }    
 
    } 
 
}

2.POI 生成

Java代码 
package excel; 
 
import java.io.FileOutputStream; 
import java.text.SimpleDateFormat; 
import java.util.Date; 
 
import org.apache.poi.hssf.usermodel.HSSFWorkbook; 
import org.apache.poi.ss.usermodel.Cell; 
import org.apache.poi.ss.usermodel.CellStyle; 
import org.apache.poi.ss.usermodel.DataFormat; 
import org.apache.poi.ss.usermodel.Row; 
import org.apache.poi.ss.usermodel.Sheet; 
import org.apache.poi.ss.usermodel.Workbook; 
import org.apache.poi.ss.util.CellRangeAddress; 
 
 
/***********************************************************************   
*   
*   @copyright       Copyright: 2012     
*   @creator         sinbong.com  
***********************************************************************/ 
public class poiCreate { 
 
    /**
     * @param args
     */ 
    public static void main(String[] args) throws Exception { 
        //创建一个EXCEL 
        Workbook wb = new HSSFWorkbook(); 
        DataFormat format = wb.createDataFormat(); 
        CellStyle style; 
        //创建一个SHEET 
        Sheet sheet1 = wb.createSheet("产品清单"); 
        String[] title = {"编号","产品名称","产品价格","产品数量","生产日期","产地","是否出口"}; 
        int i=0; 
        //创建一行 
        Row row = sheet1.createRow((short)0); 
        //填充标题 
        for (String  s:title){ 
            Cell cell = row.createCell(i); 
            cell.setCellValue(s); 
            i++; 
        } 
        Row row1 = sheet1.createRow((short)1); 
        //下面是填充数据 
        row1.createCell(0).setCellValue(20071001); 
        row1.createCell(1).setCellValue("金鸽瓜子"); 
        //创建一个单元格子 
        Cell cell2=row1.createCell(2); 
        // 填充产品价格 
        cell2.setCellValue(2.45); 
        style = wb.createCellStyle(); 
        style.setDataFormat(format.getFormat("#.##")); 
        //设定样式 
        cell2.setCellStyle(style); 
        // 填充产品数量 
        row1.createCell(3).setCellValue(200); 
        /*  
         * 定义显示日期的公共格式  
         * 如:yyyy-MM-dd hh:mm  
         * */ 
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");    
        String newdate = sdf.format(new Date());  
        // 填充出产日期    
        row1.createCell(4).setCellValue(newdate); 
        row1.createCell(5).setCellValue("陕西西安"); 
        /*  
         * 显示布尔值  
         * */  
        row1.createCell(6).setCellValue(true); 
        /*  
         * 合并单元格  
         * 通过writablesheet.mergeCells(int x,int y,int m,int n);来实现的  
         * 表示将first row, last row,first column,last column
         *   
         * */   
        Row row2 = sheet1.createRow((short) 2); 
         Cell cell3 = row2.createCell((short) 0); 
         cell3.setCellValue("合并了三个单元格"); 
        sheet1.addMergedRegion(new CellRangeAddress(2,2,0,2)); 
         
        FileOutputStream fileOut = new FileOutputStream("d:\\test.xls"); 
        wb.write(fileOut); 
        fileOut.close(); 
 
 
    } 
 

   上面代码2中方式生成 2张报表,涉及到基本生成报表中的几种单元格类型。
   POI 用的JAR poi-3.6-20091214.jar   jxl 用到的jar  jxl-2.6.jar
   2 种方式都相对比较好用,个人推荐使用POI (apache的项目)
     相关参考资料可以去官方网站查看
    http://poi.apache.org/spreadsheet/quick-guide.html

文章评论

一个程序员的时间管理
一个程序员的时间管理
如何成为一名黑客
如何成为一名黑客
旅行,写作,编程
旅行,写作,编程
Java程序员必看电影
Java程序员必看电影
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
漫画:程序员的工作
漫画:程序员的工作
为什么程序员都是夜猫子
为什么程序员都是夜猫子
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
程序员必看的十大电影
程序员必看的十大电影
程序员都该阅读的书
程序员都该阅读的书
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
中美印日四国程序员比较
中美印日四国程序员比较
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
 程序员的样子
程序员的样子
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
程序员和编码员之间的区别
程序员和编码员之间的区别
编程语言是女人
编程语言是女人
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
鲜为人知的编程真相
鲜为人知的编程真相
程序员的鄙视链
程序员的鄙视链
老程序员的下场
老程序员的下场
程序员应该关注的一些事儿
程序员应该关注的一些事儿
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
我的丈夫是个程序员
我的丈夫是个程序员
每天工作4小时的程序员
每天工作4小时的程序员
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
代码女神横空出世
代码女神横空出世
总结2014中国互联网十大段子
总结2014中国互联网十大段子
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
10个调试和排错的小建议
10个调试和排错的小建议
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
那些争议最大的编程观点
那些争议最大的编程观点
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有