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结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/417437.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[数据集][目标检测]玉米病害检测数据集VOC+YOLO格式6000张4类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;6000 标注数量(xml文件个数)&#xff1a;6000 标注数量(txt文件个数)&#xff1a;6000 标注…

《Linux运维总结:基于X86_64+ARM64架构CPU使用docker-compose一键离线部署consul 1.18.1容器版分布式ACL集群》

总结&#xff1a;整理不易&#xff0c;如果对你有帮助&#xff0c;可否点赞关注一下&#xff1f; 更多详细内容请参考&#xff1a;《Linux运维篇&#xff1a;Linux系统运维指南》 一、部署背景 由于业务系统的特殊性&#xff0c;我们需要面向不通的客户安装我们的业务系统&…

[数据集][目标检测]街道乱放广告牌检测数据集VOC+YOLO格式114张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;114 标注数量(xml文件个数)&#xff1a;114 标注数量(txt文件个数)&#xff1a;114 标注类别…

【数据结构】顺序表和链表——顺序表(包含丰富算法题)

文章目录 1. 线性表2. 顺序表2.1 概念与结构2.2 分类2.2.1 静态顺序表2.2.2 动态顺序表 2.3 动态顺序表的实现2.4 顺序表算法题2.4.1 移除元素2.4.2 删除有序数组中的重复项2.4.3 合并两个有序数组 2.5 顺序表问题与思考 1. 线性表 线性表&#xff08;linear list&#xff09;…

数据分析:R语言计算XGBoost线性回归模型的SHAP值

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍SHAP用途计算方法:应用加载R包导入数据数据预处理函数模型介绍 SHAP(SHapley Additive exPlanations)值是一种解释机器学习模型预测的方法。它基于博弈论中的Shapley值概念,…

Vulnhub:hacksudo2

靶机下载地址 信息收集 主机发现 nmap 192.168.31.0/24 -Pn -T4 靶机ip&#xff1a;192.168.31.188 端口扫描 nmap 192.168.31.188 -A -p- -T4 开放端口有80,111,1337(ssh),2049(nfs)。 目录扫描 访问http服务。 点击图片进入游戏。玩了一下没看到什么信息。 目录扫描。…

地理信息科学在考古学中的应用:GIS与遥感技术的时空穿梭之旅

在历史的长河中&#xff0c;每一片土地都承载着文明的记忆。随着科技的进步&#xff0c;地理信息科学&#xff08;GIS&#xff09;与遥感技术正逐渐揭开古老秘密的面纱&#xff0c;让沉睡千年的历史遗迹重新焕发光彩。今天&#xff0c;就让我们踏上一场穿越时空的旅程&#xff…

(一)使用Visual Studio创建ASP.NET Core WebAPI项目

1.创建webAPI项目 选择ASP.NET Core Web API项目模版&#xff08;基于.Core框架可以支持多种系统环境&#xff0c;所以我们选择.Core框架&#xff09;&#xff0c;点下一步。 2.项目名称 项目名称设置为&#xff1a;CoreWebAPI&#xff0c;点下一步 3.选择框架 选择.NET6.0框…

人机融合智能中的计算不可约性

计算的不可约性 是计算理论和复杂性科学中的一个重要概念&#xff0c;主要由 计算机科学家 和 数学家 提出和研究。它指的是在某些系统或过程的模拟中&#xff0c;没有简化或有效的方式来预测其行为&#xff0c;而必须逐步进行每一步的计算来获得结果。 不可约性定义&#xff1…

结构开发笔记(七):solidworks软件(六):装配摄像头、摄像头座以及螺丝,完成摄像头结构示意图

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/141931518 长沙红胖子Qt&#xff08;长沙创微智科&#xff09;博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV…

Java-IO:浅谈对NIO的认识

Java-IO&#xff1a;简述常见的IO模型 Java-IO&#xff1a;浅谈对IO的认识 NIO即New IO&#xff0c;这个库是在JDK1.4中才引入的。NIO和IO有相同的作用和目的&#xff0c;但实现方式不同&#xff0c;NIO 主要用到的是块&#xff0c;所以NIO的效率要比IO高很多。在Java API中提供…

LabVIEW如何自学成为专业开发者

自学成为LabVIEW专业开发者需要一个系统化的学习和实践过程&#xff0c;以下是一些关键步骤&#xff1a; 1. 扎实的基础学习 了解LabVIEW的基础概念&#xff1a;首先要熟悉LabVIEW的基本操作、数据流编程理念和图形化编程环境。可以通过LabVIEW的官方教程、Bilibili上的视频课程…

Github 2024-09-02 开源项目周报 Top13

根据Github Trendings的统计,本周(2024-09-02统计)共有13个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目3TypeScript项目3Vue项目2Rust项目2Go项目2Dart项目1Jupyter Notebook项目1Shell项目1Dockerfile项目1PHP项目1Blade项目1AI.AppFlow…

Matlab三维图的坐标轴标签 自动平行坐标/自动旋转

下载解压工具包&#xff1a; https://www.mathworks.com/matlabcentral/fileexchange/49542-phymhan-matlab-axis-label-alignment 添加至MATLAB路径: 在三维绘图后增加下列语句即可 ax struct(Axes, gca); align_axislabel([],ax) h3d rotate3d; set(h3d,ActionPreCa…

认识正则表达式

为什么要学习正则表达式 因为爬虫需要&#xff01;&#xff01;&#xff01; 一般来说爬虫需要四个主要步骤&#xff1a; 明确目标 (要知道你准备在哪个范围或者网站去搜索)爬 (将所有的网站的内容全部爬下来)取 (去掉对我们没用处的数据)处理数据&#xff08;按照我们想要的方…

在Centos中的mysql的备份与恢复

1.物理备份 冷备份&#xff1a;关闭数据库时进行热备份&#xff1a;数据库运行时进行&#xff0c;依赖于数据库日志文件温备份&#xff1a;数据库不可写入但可读的状态下进行 2.逻辑备份 对数据库的表或者对象进行备份 3.备份策略 完全备份&#xff1a;每次都备份完整的数…

使用C语言实现字符推箱子游戏

使用C语言实现字符推箱子游戏 推箱子&#xff08;Sokoban&#xff09;是一款经典的益智游戏&#xff0c;玩家通过移动角色将箱子推到目标位置。本文将带你一步步用C语言实现一个简单的字符版本的推箱子游戏。 游戏规则 玩家只能推箱子&#xff0c;不能拉箱子。只能将箱子推到…

Unity界面、组件以及脚本

Unity界面 菜单栏 菜单栏&#xff1a;位于屏幕顶部&#xff0c;包含文件、编辑、资产、游戏对象、组件、地形、动画、图形、AI、窗口、工具和帮助等菜单项。 工具栏 工具栏&#xff1a;位于菜单栏下方&#xff0c;提供了快速访问常用功能的按钮&#xff0c;如播放、暂停、停止…

OpenGL/GLUT实践:实现反弹运动的三角形动画与键盘控制(电子科技大学信软图形与动画Ⅱ实验)

源码见GitHub&#xff1a;A-UESTCer-s-Code 文章目录 1 运行效果2 实验过程2.1 环境配置2.2 绘制三角形2.2.1 渲染函数2.2.2 主函数2.2.3 运行结果 2.3 调整窗口大小2.4 简单动画与按键控制2.4.1 简单旋转2.4.2 键盘控制 2.5 窗口反弹动画2.5.1 处理窗口大小变化2.5.2 渲染函数…

c++修炼之路之C++11

目录 一&#xff1a;使用列表初始化 二&#xff1a;decltype和nullptr 三&#xff1a;右值引用和移动语义 四&#xff1a;新的类功能 五&#xff1a;可变参数模板 六&#xff1a;lambda表达式 七&#xff1a;包装器 1.function包装器 2.bind包装器 接下来的日子会顺…