- 浏览: 1791622 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
奔跑的小牛:
例子都打不开
如何使用JVisualVM进行性能分析 -
蜗牛coder:
好东西[color=blue][/color]
Lucene学习:全文检索的基本原理 -
lovesunweina:
不在haoop中是在linux系统中,映射IP的时候,不能使用 ...
java.io.IOException: Incomplete HDFS URI, no host -
evening_xxxy:
挺好的, 谢谢分享
如何利用 JConsole观察分析Java程序的运行,进行排错调优 -
di1984HIT:
学习了~~~
ant使用ssh和linux交互 如:上传文件
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(); } } } }
发表评论
-
如何使用JVisualVM进行性能分析
2011-09-25 22:32 84997地址:https://visualvm.dev.java.ne ... -
JDK5中的concurrent包、线程池
2011-02-19 23:43 5095concurrent并发包里面几个 ... -
如何利用 JConsole观察分析Java程序的运行,进行排错调优
2010-11-12 18:38 187445一、JConsole是什么 从Java 5开始 引入 ... -
gentoo下 JAVA生成图片的问题 以及JFreeChart的图片问题
2010-11-05 17:21 6895=============================== ... -
JAVA NIO 详解Buffer类
2010-10-19 11:21 16588讲得很好,转载一下:http://www.java1995 ... -
简单的记录下 jconsole 查看远程机器的JAVA程序运行状况
2010-09-07 14:31 1799简单实用 远端: java \ ... -
项目管理 进度表
2010-06-27 14:43 4013项目管理中很重要的一部分 进度管理,进度管理又牵扯到进度表 ... -
JAVA基础 对象克隆 实现java.lang.Cloneable接口
2010-04-23 13:46 6099先来看看JDK的解释: ... -
深入浅出Java 类加载器
2010-03-05 11:42 4521简介: 类加载 ... -
Jave EE 6特性:依赖注入、Bean验证和EJB增强
2009-12-18 16:19 2104Java EE 的最新版本提供 ... -
JVM优化之调整大内存分页(LargePage)
2009-11-26 12:50 4240http://kenwu.me/tune-large-page ... -
java内存模型详解
2009-11-26 12:30 2489好读书求甚解,共享展 ... -
JVM调优总结(一)一些概念
2009-11-24 14:43 1494原文地址:http://pengjiahe ... -
CentOS 5.2下配置Java和TOMCAT环境
2009-10-17 14:29 3779安装JDK: 1、下载解压(tar zxvf jdk.. ... -
web项目定时执行任务
2009-08-27 18:19 4336xml文件内容-监听器 < ... -
JAVA多线程的控制JAVA 5.0
2009-08-20 13:38 20025在Java 5.0之前启动一个任务是通过调用Thre ... -
JDK自带VM分析工具jps,jstat,jmap,jconsole
2009-08-09 10:24 35275一、概述 SUN ... -
log4j入门与提高-实例讲解
2009-08-04 09:47 6931官方网站:http://logging.apache.org/ ... -
获取Servlet运行环境信息-Servlet自身信息、Servlet服务器端信息和Servlet客户端信息
2009-07-08 15:01 7228在Servlet中可以很方便的获取各种运行环境信息,这些信 ... -
使用Perf4J进行性能分析和监控
2009-06-19 10:28 3572作者 Alex Devine 译者 崔 ...
相关推荐
java是不能提供java调用excel里的函数的,所以我提供这个例子,让大家参考,必须导入jxl.jar包哦!
### Java操作Excel教程详解 #### 一、POI简介与背景 **Jakarta POI** 是Apache的一个子项目,它的主要目标是处理OLE2对象。POI提供了一组用于操作Microsoft Office文件(如Word和Excel)的Java API。其中,**HSSF*...
POI提供了HSSF(用于旧的BIFF格式,适用于Excel 97-2003)和XSSF(用于新的XML格式,适用于Excel 2007及以上版本)两个接口来操作Excel。 1. **Apache POI(HSSF/XSSF)操作Excel:** - **创建Excel文件:** 可以...
首先,我们关注的标题"Java操作Excel和Word"涉及到两个主要部分:Excel和Word的API接口。对于Excel,Java中最常用的是Apache POI库,它是一个开源项目,提供了读取、写入Microsoft Office格式文件的能力,包括Excel...
这篇博文"利用JAVA操作EXCEL文件"很可能是介绍如何使用Java API来读写Excel文件的方法。以下是对这个主题的详细讲解: 1. **Java与Excel交互的库** - **Apache POI**:Apache POI是一个流行的开源项目,提供了API...
### Java操作Excel教程知识点梳理 #### 一、引言 在日常工作中,Excel作为一种常见的数据存储和处理工具,被广泛应用于各个领域。然而,在需要批量处理大量Excel文件时,手动操作变得不再可行。这时,利用Java编程...
在压缩包文件"excelToCsv"中,通常会包含一个示例Java程序,该程序实现了上述步骤,你可以参考它来理解和实践这个过程。通过这个程序,你可以将任意的Excel文件转换为CSV格式,方便后续的数据处理和分析。
#### 1.1 JSP操作Excel工具汇总 在Java生态中,处理Excel文档有几种流行的开源解决方案,其中最为知名的有两种:Apache POI 和 JExcelApi (jxl)。 - **Apache POI**: - **简介**:Apache POI 是 Apache Software...
Java导出Excel是Java开发中常见的需求,尤其是在数据处理和报表生成方面。Apache POI库是Java领域中广泛使用的工具,它允许开发者读写Microsoft Office格式的文件,包括Excel(.xlsx和.xls)。本篇文章将深入讲解...
Java操作Excel表格主要依赖于第三方库,如"jxl",这是一个非常流行的库,使得Java开发者可以方便地读取、写入以及修改Excel文件。在本案例中,提供的压缩包"jxljar.zip"中包含的就是这个库的JAR文件,名为"jxljar",...
总结来说,"java操作excel工作表类库和chm格式的帮助文档"提供了使用Java处理Excel文件的工具和参考资料。Apache POI和JExcelAPI提供了强大的Excel操作能力,而CHM格式的帮助文档则作为开发过程中的指南,辅助开发者...
Java的Apache POI库是一个强大的工具,用于读取、创建和修改Microsoft Office格式的文件,尤其是Excel(.xlsx)文档。...这个压缩包中的“EexcelChart”可能是示例代码、测试数据或生成的Excel文件,供用户参考和实践。
本教程“Java操作Excel之Poi视频教程”由java1234出品,旨在深入讲解如何使用Java POI进行Excel处理。 1. **什么是Apache POI?** Apache POI 是一个开源项目,它提供了API,使得Java程序能够处理Microsoft Office...
下面将详细介绍如何使用Java POI来操作Excel以及相关的知识点。 1. **基本概念** - HSSF(Horrible Spreadsheet Format):这是POI库处理Excel 97-2003(.xls)格式的部分。HSSF提供了一套API,可以创建、修改和...
通过以上步骤,你可以轻松地在Java项目中导入和操作Excel表格。结合源码和工具,可以构建出高效的数据处理系统。在开发过程中,参考Apache POI的官方文档和相关博客文章(如给出的链接),可以帮助你解决具体问题并...
Apache POI提供了丰富的API,使得开发者能够使用Java处理Excel文件的各种操作,如读取、写入、修改等。描述中还提到,这个资源来自于CSDN(Chinese Software Developer Network)网上平台,一个中国程序员交流和学习...
用Java语言采用接口设计模式、代理设计模式、工厂设计模式实现对excel中的表实现基本的...使用Java内置的poi jar包实现excel的操作,使用工厂模式、DAO设计模式等,思想很简单,可供设计模式参考,包括代码+文档+jar包
本项目就是这样一个示例,它利用了Apache POI库来处理Excel文件的生成,使得Java程序能够方便地操作Excel数据。下面将详细阐述相关知识点。 1. **Apache POI**:Apache POI是一个开源项目,它提供了Java API来读写...
Java Excel API是一个强大的工具,允许Java开发者方便地读取、写入和操作Microsoft Excel文件。在Eclipse这样的集成开发环境中,使用Java Excel API可以轻松处理各种Excel数据操作任务。本教程将详细介绍如何在...
3. **Excel操作**: 生成的二维码需要存储到Excel文件中,这通常需要用到Apache POI库。POI是用于读写Microsoft Office格式档案的Java API,可以方便地创建、修改Excel工作簿。你需要创建一个Workbook对象,添加...