`

JAVA操作Excel参考

    博客分类:
  • Java
阅读更多

  Java Excel是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容、创建新的Excel文件、更新已经存在的Excel文件。

    今天突然翻到了以前的一个测试,好像也是从哪里拷贝修改改过的,注释里有个IBM的链接 http://www.ibm.com/developerworks/cn/java/l-javaExcel/?ca=j-t10,贴上来当作一个入门参考资料吧。

import java.io.File;
import java.io.IOException;

import jxl.Cell;
import jxl.HeaderFooter;
import jxl.Sheet;
import jxl.Workbook;
import jxl.format.VerticalAlignment;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableImage;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;

/**
 * @author cjj 2008-12-22 参考:
 *         http://www.ibm.com/developerworks/cn/java/l-javaExcel/?ca=j-t10
 * 
 * 
 */
public class ExcelUtils
{
	/**
	 * 读取Excel文件的内容
	 * 
	 * @param file
	 *            待读取的文件
	 * @return
	 */
	public static String readExcel(final File file)
	{
		final StringBuffer sb = new StringBuffer();

		Workbook wb = null;
		try
		{
			//构造Workbook(工作薄)对象   
			wb = Workbook.getWorkbook(file);
		}
		catch (final BiffException e)
		{
			e.printStackTrace();
		}
		catch (final IOException e)
		{
			e.printStackTrace();
		}

		if (wb == null) return null;

		//获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了   
		final Sheet[] sheet = wb.getSheets();

		if (sheet != null && sheet.length > 0)
		{
			//对每个工作表进行循环   
			for (int i = 0; i < sheet.length; i++)
			{
				//得到当前工作表的行数   
				final int rowNum = sheet[i].getRows();
				for (int j = 0; j < rowNum; j++)
				{
					//得到当前行的所有单元格   
					final Cell[] cells = sheet[i].getRow(j);
					if (cells != null && cells.length > 0)
					{
						//对每个单元格进行循环   
						for (int k = 0; k < cells.length; k++)
						{
							//读取当前单元格的值   
							final String cellValue = cells[k].getContents();
							sb.append(cellValue + "\t");
						}
					}
					sb.append("\r\n");
				}
				sb.append("\r\n");
			}
		}
		//最后关闭资源,释放内存   
		wb.close();
		return sb.toString();
	}

	/**
	 * 生成一个Excel文件
	 * 
	 * @param fileName
	 *            要生成的Excel文件名
	 */
	public static void writeExcel(final String fileName)
	{
		WritableWorkbook wwb = null;
		//格式化
		final WritableCellFormat totalFormat = new WritableCellFormat();
		try
		{
			//首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象   
			wwb = Workbook.createWorkbook(new File(fileName));
			//格式化剧中
			totalFormat.setVerticalAlignment(VerticalAlignment.CENTRE);

		}
		catch (final IOException e)
		{
			e.printStackTrace();
		}
		catch (final WriteException e)
		{
			e.printStackTrace();
		}
		if (wwb != null)
		{
			//创建一个可写入的工作表   
			//Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置   
			final WritableSheet ws = wwb.createSheet("sheet1", 0);

			//下面开始添加单元格   
			for (int i = 0; i < 10; i++)
			{
				for (int j = 0; j < 5; j++)
				{
					//这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行   
					final Label labelC = new Label(j, i, "这是第" + (i + 1) + "行,第" + (j + 1) + "列", totalFormat);
					try
					{
						//将生成的单元格添加到工作表中   
						ws.addCell(labelC);
					}
					catch (final RowsExceededException e)
					{
						e.printStackTrace();
					}
					catch (final WriteException e)
					{
						e.printStackTrace();
					}

				}
			}

			try
			{
				//把 单元格(column, row)到单元格(column1, row1)进行合并。
				ws.mergeCells(6, 0, 6, 3);
				//从内存中写入文件中   
				wwb.write();
				//关闭资源,释放内存   
				wwb.close();
			}
			catch (final IOException e)
			{
				e.printStackTrace();
			}
			catch (final WriteException e)
			{
				e.printStackTrace();
			}
		}
	}

	/**
	 * 搜索某一个文件中是否包含某个关键字
	 * 
	 * @param file
	 *            待搜索的文件
	 * @param keyWord
	 *            要搜索的关键字
	 * @return
	 */
	public static boolean searchKeyWord(final File file, final String keyWord)
	{
		boolean res = false;

		Workbook wb = null;
		try
		{
			//构造Workbook(工作薄)对象   
			wb = Workbook.getWorkbook(file);
		}
		catch (final BiffException e)
		{
			return res;
		}
		catch (final IOException e)
		{
			return res;
		}

		if (wb == null) return res;

		//获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了   
		final Sheet[] sheet = wb.getSheets();

		boolean breakSheet = false;

		if (sheet != null && sheet.length > 0)
		{
			//对每个工作表进行循环   
			for (int i = 0; i < sheet.length; i++)
			{
				if (breakSheet) break;

				//得到当前工作表的行数   
				final int rowNum = sheet[i].getRows();

				boolean breakRow = false;

				for (int j = 0; j < rowNum; j++)
				{
					if (breakRow) break;
					//得到当前行的所有单元格   
					final Cell[] cells = sheet[i].getRow(j);
					if (cells != null && cells.length > 0)
					{
						boolean breakCell = false;
						//对每个单元格进行循环   
						for (int k = 0; k < cells.length; k++)
						{
							if (breakCell) break;
							//读取当前单元格的值   
							final String cellValue = cells[k].getContents();
							if (cellValue == null) continue;
							if (cellValue.contains(keyWord))
							{
								res = true;
								breakCell = true;
								breakRow = true;
								breakSheet = true;
							}
						}
					}
				}
			}
		}
		//最后关闭资源,释放内存   
		wb.close();

		return res;
	}

	/**
	 * 往Excel中插入图片
	 * 
	 * @param dataSheet
	 *            待插入的工作表
	 * @param col
	 *            图片从该列开始
	 * @param row
	 *            图片从该行开始
	 * @param width
	 *            图片所占的列数
	 * @param height
	 *            图片所占的行数
	 * @param imgFile
	 *            要插入的图片文件
	 */
	public static void insertImg(	final WritableSheet dataSheet,
									final int col,
									final int row,
									final int width,
									final int height,
									final File imgFile)
	{
		final WritableImage img = new WritableImage(col, row, width, height, imgFile);
		dataSheet.addImage(img);
	}

	/**
	 * 向Excel中加入页眉页脚
	 * 
	 * @param dataSheet
	 *            待加入页眉的工作表
	 * @param left
	 * @param center
	 * @param right
	 */
	public static void setHeader(	final WritableSheet dataSheet,
									final String left,
									final String center,
									final String right)
	{
		final HeaderFooter hf = new HeaderFooter();
		hf.getLeft().append(left);
		hf.getCentre().append(center);
		hf.getRight().append(right);
		//加入页眉   
		dataSheet.getSettings().setHeader(hf);
		//加入页脚   
		//dataSheet.getSettings().setFooter(hf);   
	}

	//测试
	public static void main(final String[] arts)
	{

		//测试写
		ExcelUtils.writeExcel("test.xls");

		if (false)
		{
			//测试插入页眉页脚
			try
			{
				//创建一个工作薄   
				final WritableWorkbook workbook = Workbook.createWorkbook(new File("test.xls"));
				//待插入的工作表   
				final WritableSheet dataSheet = workbook.createSheet("加入页眉", 0);
				ExcelUtils.setHeader(dataSheet, "chb", "2007-03-06", "第1页,共3页");
				workbook.write();
				workbook.close();
			}
			catch (final IOException e)
			{
				e.printStackTrace();
			}
			catch (final WriteException e)
			{
				e.printStackTrace();
			}
		}

		if (false)
		{
			//测试插入图片
			try
			{
				//创建一个工作薄   
				final WritableWorkbook workbook = Workbook.createWorkbook(new File("D:/testxls"));
				//待插入的工作表   
				final WritableSheet imgSheet = workbook.createSheet("Images", 0);
				//要插入的图片文件   
				final File imgFile = new File("D:/png");
				//图片插入到第二行第一个单元格,长宽各占六个单元格   
				insertImg(imgSheet, 0, 1, 6, 6, imgFile);
				workbook.write();
				workbook.close();
			}
			catch (final IOException e)
			{
				e.printStackTrace();
			}
			catch (final WriteException e)
			{
				e.printStackTrace();
			}
		}

	}
}
 
分享到:
评论

相关推荐

    java操作excel,函数计算

    java是不能提供java调用excel里的函数的,所以我提供这个例子,让大家参考,必须导入jxl.jar包哦!

    最全最实用的Java操作Excel教程

    ### Java操作Excel教程详解 #### 一、POI简介与背景 **Jakarta POI** 是Apache的一个子项目,它的主要目标是处理OLE2对象。POI提供了一组用于操作Microsoft Office文件(如Word和Excel)的Java API。其中,**HSSF*...

    Java操作Excel表两种方式

    POI提供了HSSF(用于旧的BIFF格式,适用于Excel 97-2003)和XSSF(用于新的XML格式,适用于Excel 2007及以上版本)两个接口来操作Excel。 1. **Apache POI(HSSF/XSSF)操作Excel:** - **创建Excel文件:** 可以...

    Java操作Excel和Word

    首先,我们关注的标题"Java操作Excel和Word"涉及到两个主要部分:Excel和Word的API接口。对于Excel,Java中最常用的是Apache POI库,它是一个开源项目,提供了读取、写入Microsoft Office格式文件的能力,包括Excel...

    利用 JAVA 操作 EXCEL 文件

    这篇博文"利用JAVA操作EXCEL文件"很可能是介绍如何使用Java API来读写Excel文件的方法。以下是对这个主题的详细讲解: 1. **Java与Excel交互的库** - **Apache POI**:Apache POI是一个流行的开源项目,提供了API...

    java 操作 excel教程

    ### Java操作Excel教程知识点梳理 #### 一、引言 在日常工作中,Excel作为一种常见的数据存储和处理工具,被广泛应用于各个领域。然而,在需要批量处理大量Excel文件时,手动操作变得不再可行。这时,利用Java编程...

    java实现excel转csv

    在压缩包文件"excelToCsv"中,通常会包含一个示例Java程序,该程序实现了上述步骤,你可以参考它来理解和实践这个过程。通过这个程序,你可以将任意的Excel文件转换为CSV格式,方便后续的数据处理和分析。

    Java对Excel表格的操作

    #### 1.1 JSP操作Excel工具汇总 在Java生态中,处理Excel文档有几种流行的开源解决方案,其中最为知名的有两种:Apache POI 和 JExcelApi (jxl)。 - **Apache POI**: - **简介**:Apache POI 是 Apache Software...

    java导出excel POI jar包

    Java导出Excel是Java开发中常见的需求,尤其是在数据处理和报表生成方面。Apache POI库是Java领域中广泛使用的工具,它允许开发者读写Microsoft Office格式的文件,包括Excel(.xlsx和.xls)。本篇文章将深入讲解...

    jxljar.zip用于java操作Excel表格

    Java操作Excel表格主要依赖于第三方库,如"jxl",这是一个非常流行的库,使得Java开发者可以方便地读取、写入以及修改Excel文件。在本案例中,提供的压缩包"jxljar.zip"中包含的就是这个库的JAR文件,名为"jxljar",...

    java操作excel工作表类库和chm格式的帮助文档

    总结来说,"java操作excel工作表类库和chm格式的帮助文档"提供了使用Java处理Excel文件的工具和参考资料。Apache POI和JExcelAPI提供了强大的Excel操作能力,而CHM格式的帮助文档则作为开发过程中的指南,辅助开发者...

    java的poi生成excel图表demo

    Java的Apache POI库是一个强大的工具,用于读取、创建和修改Microsoft Office格式的文件,尤其是Excel(.xlsx)文档。...这个压缩包中的“EexcelChart”可能是示例代码、测试数据或生成的Excel文件,供用户参考和实践。

    Java操作Excel之Poi视频教程 java1234出品

    本教程“Java操作Excel之Poi视频教程”由java1234出品,旨在深入讲解如何使用Java POI进行Excel处理。 1. **什么是Apache POI?** Apache POI 是一个开源项目,它提供了API,使得Java程序能够处理Microsoft Office...

    java poi 操作Excel

    下面将详细介绍如何使用Java POI来操作Excel以及相关的知识点。 1. **基本概念** - HSSF(Horrible Spreadsheet Format):这是POI库处理Excel 97-2003(.xls)格式的部分。HSSF提供了一套API,可以创建、修改和...

    java导入excel表格

    通过以上步骤,你可以轻松地在Java项目中导入和操作Excel表格。结合源码和工具,可以构建出高效的数据处理系统。在开发过程中,参考Apache POI的官方文档和相关博客文章(如给出的链接),可以帮助你解决具体问题并...

    excel转换html类(Excel2HtmlUtil的JAVA类)

    Apache POI提供了丰富的API,使得开发者能够使用Java处理Excel文件的各种操作,如读取、写入、修改等。描述中还提到,这个资源来自于CSDN(Chinese Software Developer Network)网上平台,一个中国程序员交流和学习...

    JAVA实现excel的导出.zip

    用Java语言采用接口设计模式、代理设计模式、工厂设计模式实现对excel中的表实现基本的...使用Java内置的poi jar包实现excel的操作,使用工厂模式、DAO设计模式等,思想很简单,可供设计模式参考,包括代码+文档+jar包

    Java数据导出到Excel模板

    本项目就是这样一个示例,它利用了Apache POI库来处理Excel文件的生成,使得Java程序能够方便地操作Excel数据。下面将详细阐述相关知识点。 1. **Apache POI**:Apache POI是一个开源项目,它提供了Java API来读写...

    Java Excel Api及详细教程

    Java Excel API是一个强大的工具,允许Java开发者方便地读取、写入和操作Microsoft Excel文件。在Eclipse这样的集成开发环境中,使用Java Excel API可以轻松处理各种Excel数据操作任务。本教程将详细介绍如何在...

    java excel生成二维码(可以添加图标和文字).zip

    3. **Excel操作**: 生成的二维码需要存储到Excel文件中,这通常需要用到Apache POI库。POI是用于读写Microsoft Office格式档案的Java API,可以方便地创建、修改Excel工作簿。你需要创建一个Workbook对象,添加...

Global site tag (gtag.js) - Google Analytics