java利用JXL操作excel

2024-09-01 21:20
文章标签 java excel 操作 jxl

本文主要是介绍java利用JXL操作excel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通过JXL操作Excel JXL是韩国人所著,目前停止更新,只支持xls格式,即2007之前的版本


import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;
import java.util.Date;import jxl.Cell;
import jxl.CellType;
import jxl.Sheet;
import jxl.Workbook;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.Colour;
import jxl.format.UnderlineStyle;
import jxl.format.VerticalAlignment;
import jxl.read.biff.BiffException;
import jxl.write.DateFormat;
import jxl.write.Formula;
import jxl.write.Label;
import jxl.write.NumberFormat;
import jxl.write.WritableCellFeatures;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableHyperlink;
import jxl.write.WritableImage;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;/*** 1.通过Apache POI 操作Excel Apache POI是用Java编写的免费开源的跨平台的 Java API,Apache* POI提供API给Java对Microsoft Office格式档案读和写的功能 常用的包: HSSF - 提供读写Microsoft Excel* XLS格式档案的功能。 XSSF - 提供读写Microsoft Excel OOXML XLSX格式档案的功能。 HWPF -* 提供读写Microsoft Word DOC格式档案的功能。 HSLF - 提供读写Microsoft PowerPoint格式档案的功能。 HDGF -* 提供读Microsoft Visio格式档案的功能。 HPBF - 提供读Microsoft Publisher格式档案的功能。 HSMF -* 提供读Microsoft Outlook格式档案的功能。 需要引用poi.jar包和poi-ooxml.jar包* * 2.通过JXL操作Excel JXL是韩国人所著,目前停止更新,只支持xls格式,即2007之前的版本* * @author LYJ**/
public class ExcelOperate {public static void main(String[] args) {writeExcelByJxl("C:\\Users\\LYJ\\Desktop\\tmp\\writeTest.xls");readExcelByJxl("C:\\Users\\LYJ\\Desktop\\tmp\\writeTest.xls");}public static void writeExcelByJxl(String file) {WritableWorkbook workbook = null;WritableSheet sheet = null;try {// 创建一个可写的工作簿workbook = Workbook.createWorkbook(new File(file));// 创建一个sheet页,名称为"sheet1"sheet = workbook.createSheet("sheet1", 0);// 定义单元格格式WritableCellFormat format1 = new WritableCellFormat();format1.setAlignment(Alignment.CENTRE);// 水平对齐format1.setVerticalAlignment(VerticalAlignment.CENTRE);// 垂直对齐WritableFont font = new WritableFont(WritableFont.TAHOMA, 18, WritableFont.BOLD, false);format1.setBorder(Border.ALL, BorderLineStyle.THIN);// 边框线 所有边框 细线format1.setBackground(Colour.GRAY_25); // 设置单元格的背景颜色format1.setWrap(false);// 文字是否换行format1.setShrinkToFit(false);// 自适应列宽format1.setFont(font);// 创建一个单元格,参数为:列(第一列从0开始),行(第一行从0开始),内容Label lable = new Label(0, 0, "姓名");// 第1行,第1列lable.setCellFormat(format1);sheet.addCell(lable);lable = new Label(1, 0, "性别");// 第1行,第2列sheet.addCell(lable);lable = new Label(2, 0, "年龄");// 第1行,第3列sheet.addCell(lable);lable = new Label(3, 0, "生日");// 第1行,第4列WritableCellFeatures cellFeatures = new WritableCellFeatures();cellFeatures.setComment("请输入日期格式");// 设置审阅备注信息lable.setCellFeatures(cellFeatures);sheet.addCell(lable);lable = new Label(4, 0, "体重");// 第1行,第5列sheet.addCell(lable);lable = new Label(5, 0, "地址");// 第1行,第6列sheet.addCell(lable);// 设置第2行内容lable = new Label(0, 1, "张三");// 第2行,第1列sheet.addCell(lable);lable = new Label(1, 1, "男");// 第2行,第2列sheet.addCell(lable);// 定义一个数字格式NumberFormat numberFormat = new NumberFormat("#");WritableCellFormat cellFormat = new WritableCellFormat(numberFormat);// 写入一个格式化的数字jxl.write.Number numberLable = new jxl.write.Number(2, 1, 20, cellFormat);// 第2行,第3列sheet.addCell(numberLable);DateFormat df = new DateFormat("yyyy/MM/dd");jxl.write.DateTime dateLable = new jxl.write.DateTime(3, 1, new Date());// 第2行,第4列cellFormat = new WritableCellFormat(df);dateLable.setCellFormat(cellFormat);sheet.addCell(dateLable);// 定义一个数字格式numberFormat = new NumberFormat("#.##");cellFormat = new WritableCellFormat(numberFormat);// 写入一个格式化的数字numberLable = new jxl.write.Number(4, 1, 65.56, cellFormat);// 第2行,第5列sheet.addCell(numberLable);lable = new Label(5, 1, "湖北省武汉市洪山区未来科技城C2栋");// 第2行,第6列// 定义单元格格式WritableCellFormat format2 = new WritableCellFormat();// 定义单元格样式:字体 下划线 斜体 粗体 颜色WritableFont font2 = new WritableFont(WritableFont.ARIAL, 12, WritableFont.NO_BOLD, false,UnderlineStyle.NO_UNDERLINE, Colour.RED);format2.setWrap(true);// 文字是否换行format2.setShrinkToFit(false);// 自适应列宽format2.setFont(font2);lable.setCellFormat(format2);sheet.addCell(lable);// 设置第3行内容lable = new Label(0, 2, "李四");// 第2行,第1列sheet.addCell(lable);lable = new Label(1, 2, "男");// 第2行,第2列sheet.addCell(lable);// 定义一个数字格式numberFormat = new NumberFormat("#");cellFormat = new WritableCellFormat(numberFormat);// 写入一个格式化的数字numberLable = new jxl.write.Number(2, 2, 23, cellFormat);// 第2行,第3列sheet.addCell(numberLable);df = new DateFormat("yyyy/MM/dd");dateLable = new jxl.write.DateTime(3, 2, new Date());// 第2行,第4列cellFormat = new WritableCellFormat(df);dateLable.setCellFormat(cellFormat);sheet.addCell(dateLable);// 定义一个数字格式numberFormat = new NumberFormat("#.##");cellFormat = new WritableCellFormat(numberFormat);// 写入一个格式化的数字numberLable = new jxl.write.Number(4, 2, 70.5, cellFormat);// 第2行,第5列sheet.addCell(numberLable);lable = new Label(5, 2, "湖北省武汉市洪山区未来科技城C2栋");// 第2行,第6列// 定义单元格格式format2 = new WritableCellFormat();// 定义单元格样式:字体 下划线 斜体 粗体 颜色font2 = new WritableFont(WritableFont.ARIAL, 12, WritableFont.NO_BOLD, false, UnderlineStyle.NO_UNDERLINE,Colour.RED);format2.setWrap(true);// 文字是否换行format2.setShrinkToFit(false);// 自适应列宽format2.setFont(font2);lable.setCellFormat(format2);sheet.addCell(lable);// 公式Formula f1 = new Formula(2, 4, "SUM(C2:C3)");sheet.addCell(f1);Formula f2 = new Formula(4, 4, "AVERAGE(E2:E3)");sheet.addCell(f2);// 图片单元格File file2 = new File("C:\\Users\\LYJ\\Desktop\\tmp\\梦之桃花源.png");WritableImage image = new WritableImage(1, 5, 3, 10, file2);// 图片从2列到第4列,占第6行第10行sheet.addImage(image);// 增加超链接单元格WritableHyperlink link = new WritableHyperlink(6, 2, new URL("http://www.baidu.com"));sheet.addHyperlink(link);// 设置行高sheet.getSettings().setDefaultRowHeight(350); // 设置所有行默认行高sheet.setRowView(0, 700);// 第1行 高度sheet.setRowView(1, 400);// 第2行 高度// 设置列宽sheet.getSettings().setDefaultColumnWidth(20);sheet.setColumnView(0, 10);// 第1列 宽度// 合并单元格(列,行,列,行)sheet.mergeCells(0, 5, 3, 5); // 第1列,第6行与第4列,第6行合并// 从内存中写入文件中workbook.write();// 关闭资源,释放内存workbook.close();} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();} catch (RowsExceededException e) {e.printStackTrace();} catch (WriteException e) {e.printStackTrace();}}public static void readExcelByJxl(String file) {try {InputStream is = new FileInputStream(file);Workbook workBook = Workbook.getWorkbook(is);Sheet sheet = workBook.getSheet(0);// 获取第一张Sheet表// 获取单元格Cell cell = sheet.getCell(0, 0);// 获取单元格内容String value = cell.getContents();System.out.println("value=" + value);int rowCount = sheet.getRows();// 得到总行数int columnCount = sheet.getColumns();// 得到总列数// 循环获取excel内容for (int i = 0; i < rowCount; i++) {for (int j = 0; j < columnCount; j++) {cell = sheet.getCell(j, i);value = cell.getContents();if (CellType.DATE == cell.getType()) {System.out.println("第" + (i + 1) + "行,第" + (j + 1) + "数据类型=" + cell.getType());}System.out.println("第" + (i + 1) + "行,第" + (j + 1) + "列的值=" + value);}}is.close();workBook.close();} catch (FileNotFoundException e) {e.printStackTrace();} catch (BiffException e) {e.printStackTrace();} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}

写入excel结果

这篇关于java利用JXL操作excel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128073

相关文章

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.