JAVA EXCEL API

转载 2006年06月02日 23:05:00

参考文章:http://www-128.ibm.com/developerworks/cn/java/l-javaExcel/index.html
作了一些相应的扩充(读取图片等)

Java Excel是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容、创建新的Excel文件、更新已经存在的Excel文件。使用该API非Windows操作系统也可以通过纯Java应用来处理Excel数据表。因为是使用Java编写的,所以我们在Web应用中可以通过JSP、Servlet来调用API实现对Excel数据表的访问。

提供以下功能:

从Excel 95、97、2000等格式的文件中读取数据;
读取Excel公式(可以读取Excel 97以后的公式);
生成Excel数据表(格式为Excel 97);
支持字体、数字、日期的格式化;
支持单元格的阴影操作,以及颜色操作;
修改已经存在的数据表;
能够读取图表信息
1.应用示例:
包括从Excel读取数据,生成新的Excel,以及修改Excel
package common.util;

import jxl.*;
import jxl.format.Underlinestyle;
import jxl.write.*;
import jxl.write.Number;
import jxl.write.Boolean;

import java.io.*;

/**
* Created by IntelliJ IDEA.
* User: xl
* Date: 2005-7-17
* Time: 9:33:22
* To change this template use File | Settings | File Templates.
*/
public class ExcelHandle
{
   public ExcelHandle()
   {
   }

   /**
    * 读取Excel
    *
    * @param filePath
    */
   public static void readExcel(String filePath)
   {
       try
       {
           InputStream is = new FileInputStream(filePath);
           Workbook rwb = Workbook.getWorkbook(is);
           //Sheet st = rwb.getSheet("0")这里有两种方法获取sheet表,1为名字,而为下标,从0开始
           Sheet st = rwb.getSheet("original");
           Cell c00 = st.getCell(0,0);
           //通用的获取cell值的方式,返回字符串
           String strc00 = c00.getContents();
           //获得cell具体类型值的方式
           if(c00.getType() == CellType.LABEL)
           {
               LabelCell labelc00 = (LabelCell)c00;
               strc00 = labelc00.getString();
           }
           //输出
           System.out.println(strc00);
           //关闭
           rwb.close();
       }
       catch(Exception e)
       {
           e.printStackTrace();
       }
   }

   /**
    * 输出Excel
    *
    * @param os
    */
   public static void writeExcel(OutputStream os)
   {
       try
       {
           /**
            * 只能通过API提供的工厂方法来创建Workbook,而不能使用WritableWorkbook的构造函数,
            * 因为类WritableWorkbook的构造函数为protected类型
            * method(1)直接从目标文件中读取WritableWorkbook wwb = Workbook.createWorkbook(new File(targetfile));
            * method(2)如下实例所示 将WritableWorkbook直接写入到输出流

            */
           WritableWorkbook wwb = Workbook.createWorkbook(os);
           //创建Excel工作表 指定名称和位置
           WritableSheet ws = wwb.createSheet("Test Sheet 1",0);

           //**************往工作表中添加数据*****************

           //1.添加Label对象
           Label label = new Label(0,0,"this is a label test");
           ws.addCell(label);

           //添加带有字型formatting对象
           WritableFont wf = new WritableFont(WritableFont.TIMES,18,WritableFont.BOLD,true);
           WritableCellformat wcf = new WritableCellformat(wf);
           Label labelcf = new Label(1,0,"this is a label test",wcf);
           ws.addCell(labelcf);

           //添加带有字体颜色的formatting对象
           WritableFont wfc = new WritableFont(WritableFont.ARIAL,10,WritableFont.NO_BOLD,false,
                   Underlinestyle.NO_UNDERLINE,jxl.format.Colour.RED);
           WritableCellformat wcfFC = new WritableCellformat(wfc);
           Label labelCF = new Label(1,0,"This is a Label Cell",wcfFC);
           ws.addCell(labelCF);

           //2.添加Number对象
           Number labelN = new Number(0,1,3.1415926);
           ws.addCell(labelN);

           //添加带有formatting的Number对象
           Numberformat nf = new Numberformat("#.##");
           WritableCellformat wcfN = new WritableCellformat(nf);
           Number labelNF = new jxl.write.Number(1,1,3.1415926,wcfN);
           ws.addCell(labelNF);

           //3.添加Boolean对象
           Boolean labelB = new jxl.write.Boolean(0,2,false);
           ws.addCell(labelB);

           //4.添加DateTime对象
           jxl.write.DateTime labelDT = new jxl.write.DateTime(0,3,new java.util.Date());
           ws.addCell(labelDT);

           //添加带有formatting的Dateformat对象
           Dateformat df = new Dateformat("dd MM yyyy hh:mm:ss");
           WritableCellformat wcfDF = new WritableCellformat(df);
           DateTime labelDTF = new DateTime(1,3,new java.util.Date(),wcfDF);
           ws.addCell(labelDTF);


           //添加图片对象,jxl只支持png格式图片
           File image = new File("f://2.png");
           WritableImage wimage = new WritableImage(0,1,2,2,image);
           ws.addImage(wimage);
           //写入工作表
           wwb.write();
           wwb.close();
       }
       catch(Exception e)
       {
           e.printStackTrace();
       }
   }

   /**
    * 拷贝后,进行修改,其中file1为被copy对象,file2为修改后创建的对象
    * 尽单元格原有的格式化修饰是不能去掉的,我们还是可以将新的单元格修饰加上去,
    * 以使单元格的内容以不同的形式表现
    * @param file1
    * @param file2
    */
   public static void modifyExcel(File file1,File file2)
   {
       try
       {
           Workbook rwb = Workbook.getWorkbook(file1);
           WritableWorkbook wwb = Workbook.createWorkbook(file2,rwb);//copy
           WritableSheet ws = wwb.getSheet(0);
           WritableCell wc = ws.getWritableCell(0,0);
           //判断单元格的类型,做出相应的转换
           if(wc.getType == CellType.LABEL)
           {
               Label label = (Label)wc;
               label.setString("The value has been modified");
           }
           wwb.write();
           wwb.close();
           rwb.close();
       }
       catch(Exception e)
       {
           e.printStackTrace();
       }
   }


   //测试
   public static void main(String[] args)
   {
       try
       {
           //读Excel
           ExcelHandle.readExcel("f:/testRead.xls");
           //输出Excel
           File fileWrite = new File("f:/testWrite.xls");
           fileWrite.createNewFile();
           OutputStream os = new FileOutputStream(fileWrite);
           ExcelHandle.writeExcel(os);
           //修改Excel
           ExcelHandle.modifyExcel(new file(""),new File(""));
       }
       catch(Exception e)
       {
          e.printStackTrace();
       }
   }
}

2.在jsp中做相关测试,创建一个writeExcel.jsp
<%
response.reset();//清除Buffer
response.setContentType("application/vnd.ms-excel");
File fileWrite = new File("f:/testWrite.xls");
fileWrite.createNewFile();
new FileOutputStream(fileWrite);
ExcelHandle.writeExcel(new FileOutputStream(fileWrite));
%>
在IE中浏览writeExcel.jsp就可以动态生成Excel文档了,其中response.setContentType("application/vnd.ms-excel");语句必须要,才能确保不乱码,在jsp中输入<%@page contentType="application/vnd.ms-excel;charset=GBK"%>不行。

java绘制excel图表(jxcell)

java语言利用jxcell.jar 绘制excel图表( 柱状图) -## 标题 ##- 因为需求需要利用java绘制图表找了很多资料最后找到了jxcell可以做这方面的东西 jxcell还可以直...
  • liujinxin33
  • liujinxin33
  • 2015年02月28日 16:14
  • 4745

POI和Java Excel Api导入导出----详细到你不敢相信

来自:http://blog.csdn.net/jerehedu/article/details/45195359     一、介绍             当前B/S模式已成为应用开发的...
  • m0_37899388
  • m0_37899388
  • 2017年05月27日 09:24
  • 8636

Java 使用jxl读取Excel文件到Txt

/** * 读取excel文件到Txt * * @author wild * */ public class TestxlsOutTxt { /** * 读取xls文件内容 *...
  • Luo_da
  • Luo_da
  • 2017年08月03日 17:08
  • 190

C# API: 生成和读取Excel文件

想为用户提供一些数据,考虑再三, 大家认为对于用户(人,而非机器)的可读性, Excel文件要好一些. 因为相比csv,xml等文件, Excel中我们可以运用自动筛选, 窗口锁定, 还可以控制...
  • lz576825608
  • lz576825608
  • 2013年05月13日 17:40
  • 1058

java中利用jxl包对Excel文件进行修改保存

今天,部门主管给我一个小任务,说是一个小任务,可是对于我来说却完全摸不着头脑,因为是第一次接触,以前都没听过,所以感觉非常不可思议!具体的任务见下图:                         ...
  • qq_30401659
  • qq_30401659
  • 2016年03月24日 20:00
  • 2318

Java 读取excel指定行列数据以及将数据保存到txt文件中

在使用的软件中经常要用到一些数据的导入导出,以及准确的定位数据,这些经常会涉及excle表格,因此把今天学习到的关于如何利用Java准确获取到excle中的某一列数据,同时将此列数据输出到txt文件格...
  • xiaoxun2802
  • xiaoxun2802
  • 2017年04月25日 20:49
  • 3843

Jsp利用pageoffice实现在线excel文档的编辑并保存到服务器

利用pageoffice实现在线处理excel文档上周开组会,发现理解错导师的意思了,老师当然希望我能自动的爬取那些信息,但是现在要的很急,希望以半自动的方式去得到这些数据存到数据库,所以这周一直在弄...
  • u014311318
  • u014311318
  • 2017年03月30日 16:31
  • 2174

借助RESTful API,用Excel开发网站,可用于多人在线实时编辑Excel,有实例下载

这里说的用Excel开发网站,就是用Excel做网站的用户界面。用户完全在EXCEL里面使用整个网站,不需要用到浏览器。 这里不能上传附件,欢迎到QQ群:558012387下载一个可以用的例...
  • u013384958
  • u013384958
  • 2016年06月30日 09:44
  • 848

java连接MongoDB查询导出为excel表格

背景 由于项目需求,每个星期需要统计每个公众号7天的访问数,月底就需要统计一个月的访问数,40多个公众号,每次手动统计都需要花费1个小时,总之是一项无技术耗时耗神的手工活。于是,想写个程序来统计,...
  • musuny
  • musuny
  • 2015年06月03日 21:37
  • 2339

JAVA笔记-如何将百万级数据高效的导出到Excel表单

EXCEL的大数据量导出
  • maoxiao1229
  • maoxiao1229
  • 2017年02月20日 09:15
  • 653
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JAVA EXCEL API
举报原因:
原因补充:

(最多只允许输入30个字)