`
cqjc
  • 浏览: 18879 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
最近访客 更多访客>>
社区版块
存档分类
最新评论

Java读、写、修改Excel文件详解

    博客分类:
  • JAVA
阅读更多
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为名字,2为下标,从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详解

    Java Excel API是一个强大的开源库,允许开发者使用Java语言轻松地创建、更新以及读取Excel文件。这个库支持多种Excel文件格式,包括较旧版本(如.xls)和较新版本(如.xlsx)。下面将详细介绍如何利用Java Excel ...

    如何用java输出Excel文件

    ### 如何用Java输出Excel文件:使用jxl库详解 在Java编程中,处理Excel文件是一种常见的需求,尤其是在企业级应用中,数据导出至Excel是数据报告、数据分析的重要环节。jxl(Java eXcel API)是一个强大的库,允许...

    java操作Excel_详解

    jExcelAPI,也称为jxl,是一个由韩国开发者创建的Java库,用于读取、写入和修改Microsoft Excel文件。它的一个显著优点是对中文字符的优秀支持,这使得它在中文环境下非常受欢迎。jxl是一个纯Java的API,这意味着它...

    Java实现Excel导入导出操作详解.pptx.pptx

    通过Apache POI的API,开发者可以轻松读取Excel文件,将数据转化为Java对象,同时也可以添加、修改和删除单元格数据,实现对Excel文件的完全控制。JXL库则是一个较简单的选项,适合小型项目和简单的Excel操作。另外...

    EXCEL文件导入:JAVA读取Excel

    它不仅仅能够读取Excel文件,还能够创建和修改Excel文件。对于那些希望在Java应用程序中集成Excel处理功能的开发者来说,POI是一个非常强大的工具。 ##### 三、POI的核心组件 **1. HSSF (Hierarchical Structure ...

    Java操作Excel方法详解

    创建Excel文件的核心在于使用`Workbook.createWorkbook()`方法来打开或创建一个新的Excel文件,然后使用`createSheet()`创建工作表,并通过`WritableSheet`对象进行进一步操作。例如在以下代码中,我们创建了一个名...

    java中导入导出Excel文件

    ### Java中导入导出Excel文件知识点详解 #### 一、POI简介 **Jakarta POI** 是 Apache 的一个子项目,旨在处理 Microsoft Office 文件格式。它为开发者提供了丰富的 API 来读取、写入、修改 Microsoft Office 文件...

    java解析并且操作excel_方法

    ### Java 解析并操作 Excel 方法详解 #### 一、引言 随着企业信息化程度的不断提高,Excel 文件在数据处理和报告生成中扮演着极其重要的角色。因此,掌握如何使用 Java 对 Excel 文件进行读写操作变得至关重要。...

    java 打印excel

    Apache POI是Java领域内一个非常强大的用于处理Microsoft Office文档的开源库,特别适用于生成、修改Excel文件。 #### 二、核心类及方法介绍 ##### 1. `HSSFWorkbook` `HSSFWorkbook`是Apache POI提供的用于操作...

    java的POI操作Excel文件.doc

    ### Java的POI操作Excel文件知识点详解 #### 一、POI简介与应用场景 Apache POI 是一个开源项目,由 Apache 软件基金会维护,主要用于处理 Microsoft Office 格式的文件,尤其是 Excel 和 Word 文件。POI 提供了一...

    POI实战-java开发excel详解

    在项目开发中,不仅需要读取Excel文件,还需要能够创建或修改Excel文件。POI提供了丰富的API来支持这些需求。 ##### 3.1 复杂写入 - **添加数据**:可以向Excel文件中添加新的行和单元格,并设置单元格的数据类型...

    Java+Excel+Api及详细教程

    本教程将涵盖以上所有知识点,通过实例代码展示如何使用Java和POI库来创建、读取和修改Excel文件。同时,也会深入讲解如何利用API处理复杂场景,如处理公式、图表和大数据量的文件。 通过学习本教程,你将能够熟练...

    Java处理Excel文件

    ### Java处理Excel文件的知识点详解 #### 一、Java与Excel交互的核心库——JXL(JExcelApi) 在Java开发中,处理Excel文件通常涉及到读取、修改、创建Excel文档的功能,而`JXL`(Java eXcel API)正是为这一需求...

    java 导入导出excel

    **修改文件**:通过`Workbook.createWorkbook(File file, Workbook book)`方法,可以打开一个Excel文件的副本,并在上面进行修改,最后将更改写回原文件。`UpdateXLS.java`示例展示了如何向现有文件中添加一个新的...

    JAVA操作EXCEL文件

    ### JAVA操作EXCEL文件知识点详解 #### 一、JAVAEXCELAPI简介 JAVAEXCELAPI是一个开源项目,专为Java开发者设计,旨在帮助他们轻松地读取、创建和更新Excel文件。这一API允许非Windows环境下的纯Java应用程序也能...

    java读xls文件成shell脚本

    这里提到的`jxl.jar`就是jxl库,它允许我们读取、写入和修改Excel文件。jxl库支持.xls格式,即Excel 97-2007的文件格式。 2. **jxl库的使用**: - **导入库**: 在Java项目中,首先需要将`jxl.jar`添加到类路径中,...

    Java处理Excel文档 含api说明文件

    Apache POI提供了一系列的API,允许开发者创建、修改和读取Excel文件。在JavaExcelAPI压缩包中,API说明文件应包含了详细的类和方法解释,这对于理解和使用POI库至关重要。 要开始处理Excel,首先需要引入Apache ...

    java使用POI操作excel (支持excel2007)

    Java 使用Apache POI库操作Excel 2007文件详解 在Java开发中,处理Excel文件是一项常见的任务,特别是对于数据分析、数据导入导出或报表生成等场景。Apache POI是一个流行的开源库,它允许开发者读写Microsoft ...

    java操作excel类

    Java作为广泛使用的编程语言,提供了多种库来实现对Excel文件的读写操作,其中较为流行的有Apache POI和JExcelAPI(jxl)。下面将详细解析基于Java的Excel操作类,涵盖其主要功能、代码示例以及使用场景。 #### 一...

    Java操作excel的jar包

    在Java编程语言中,处理Excel文件是一项常见的任务,特别是在数据导入导出、数据分析或报表生成等场景。"Java操作Excel的Jar包"指的是利用特定的Java库来读写Microsoft Excel文件。在这种情况下,我们提到的库是`jxl...

Global site tag (gtag.js) - Google Analytics