java利用JXL操作excel

news2024/9/21 5:39:11

通过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 block
			e.printStackTrace();
		}
	}

}

写入excel结果

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【论文解读】SAM模型超级进化:面向移动端的轻量级SAM,比FastSAM快4倍!(附论文地址)

论文地址&#xff1a;https://arxiv.org/pdf/2306.14289.pdf 这篇论文的标题是《FASTER SEGMENT ANYTHING: TOWARDS LIGHTWEIGHT SAM FOR MOBILE APPLICATIONS》&#xff0c;由Chaoning Zhang等人撰写&#xff0c;发表于2023年。 文章主要探讨了如何将Segment Anything Model&…

Docker构建镜像时本地NuGet不存在的解决方式

在打包镜像时&#xff0c;由于程序中使用了本地的NuGet包&#xff0c;发现怎么打包都是失败,错误如下 我的dockerfile 文件如下 FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base WORKDIR /app EXPOSE 80# 此阶段用于生成服务项目 FROM mcr.microsoft.com/dotnet/sdk:8.0 A…

战略设计(Strategic Design)

战略设计(strategic design)——一种针对系统整体的建模和设计决策。这样的决策影响整个项目&#xff0c;而且必须由团队来制定。 随着系统的增长&#xff0c;它会变得越来越复杂&#xff0c;当我们无法通过分析对象来理解系统的时候&#xff0c;就需要掌握一些操纵和理解大的模…

Docker简介及部署方法

什么是 docker &#xff1f; Docker是一个开源的应用容器引擎&#xff0c;它允许开发者将应用及其依赖打包到一个轻量级、可移植的容器中&#xff0c;并几乎可以在任何支持的平台上运行。Docker利用Linux内核的功能&#xff08;如Cgroups和namespaces&#xff09;来实现对进程的…

《JavaEE进阶》----7.<SpringMVC实践项目:【登录页面的验证】>

这篇文章详细的讲解了一个 简单的登录网页的前端代码和后端代码的构造 使用了JavaScript中的ajax来进行前后端的交互 一、前端代码 登录页面代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>登录…

从0开始深度学习(2)——自动微分

1 微积分 1.1 导数和微分 略 1.2 偏导数 略 1.3 梯度&#xff08;gradient&#xff09; 1.3.1 定义 对于一个多变量函数 f ( x 1 , x 2 , … , x n ) f\left(x_{1}, x_{2}, \ldots, x_{n}\right) f(x1​,x2​,…,xn​)其中点 a ( a 1 , a 2 , … , a n ) \mathbf{a}(a_…

【栈经典问题剖析】上

1.1进制转换 1.1.2思路图解&#xff1a; 每次将得到的余数存入栈中&#xff0c;直到商为0时&#xff0c;停止入栈。依次将栈中元素出栈并进行打印操作&#xff08;注意负数的符号情况&#xff09; //进制转换&#xff1a;10进制整数转换成8进制整数 #include <stdio.h>…

Google的MapReduce和Hadoop的MapReduce基本原理

Google的MapReduce和Hadoop的MapReduce基本原理 MapReduce框架的执行过程可以概述为以下几个关键步骤&#xff1a; 输入分割&#xff1a;用户程序中的MapReduce库首先将输入文件分割成M个片段&#xff0c;每个片段通常大小在16MB到64MB之间&#xff0c;用户可以通过可选参数控制…

【leetcode413周赛】——前两题python

3274. 检查棋盘方格颜色是否相同 给你两个字符串 coordinate1 和 coordinate2&#xff0c;代表 8 x 8 国际象棋棋盘上的两个方格的坐标。 以下是棋盘的参考图。 如果这两个方格颜色相同&#xff0c;返回 true&#xff0c;否则返回 false。 坐标总是表示有效的棋盘方格。坐标…

【indirect 函数 ★二级下拉菜单】

Indirect 函数 &#x1f33c;indirect函数参数&#x1f33c;应用&#xff1a;&#x1f33c;跨表引用同一单元格&#x1f33c;二级下拉列表 &#x1f33c;indirect函数参数 返回⬅️【文本字符串所指定的引用】 INDIRECT(ref_text,[a1]) 其中【ref_text】是引用的文本 [a1] 是…

大数据之数据湖Apache Hudi

一、Hudi框架概述 Apahe Hudi (Hadoop Upserts delete and Incrementals) 是Uber主导开发的开源数据湖框架&#xff0c;为了解决大数据生态系统中需要插入更新及增量消费原语的摄取管道和ETL管道的低效问题&#xff0c;该项目在2016年开始开发&#xff0c;并于2017年开源&#…

Mysql基础练习题 1084.销售分析3 (力扣)

编写解决方案&#xff0c;报告 2019年春季 才售出的产品。即 仅 在 2019-01-01 &#xff08;含&#xff09;至 2019-03-31 &#xff08;含&#xff09;之间出售的商品 题目链接&#xff1a; https://leetcode.cn/problems/sales-analysis-iii/description/ 建表插入数据&…

学习指纹浏览器 处理美团mtgsig1.2 环境检测

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 有相关问题请第一时间头像私信联系我…

恭喜各位天命人!2024年国自然基金放榜了!优青654项、杰青433项,附个人查询攻略

公众号&#xff1a;生信漫谈&#xff0c;获取最新科研信息&#xff01; 恭喜各位天命人&#xff01;2024年国自然基金放榜了&#xff01;优青654项、杰青433项&#xff0c;附个人查询攻略https://mp.weixin.qq.com/s?__bizMzkwNjQyNTUwMw&mid2247487048&idx1&sn1…

Webfunny前端监控如何搭建高并发使用场景

Webfunny可以支持千万级别PV的日活量了。但是&#xff0c;我们默认的部署配置&#xff0c;是无法支持这么高的日活量的&#xff0c;需要我们做一些支持高并发的配置和操作&#xff0c;下面让我们一起看下如何让webfunny支持更高的并发量吧&#xff0c;下图为webfunny高并发架构…

数据集格式转化

数据集格式转换的要点是从对应的格式中解析出对应的class和bbox 整体说明&#xff1a; lables_voc_dir&#xff1a; 为存放所有xml的标注文件夹&#xff0c;labels_yolo_dir: 为转换后存放所有xml的标注文件夹images_dir : 为所有图像文件的文件夹。、 注意&#xff1a;代码…

C++手撕简易list

目录 节点的准备 list类 push_back stl容器的遍历和修改 begin end ! 重载* 效果展示&#xff1a; const迭代器 方法一&#xff1a; 方法二&#xff1a; ->的重载 insert push_front erase 展示效果 pop_back && pop_front 效果展示 clear&am…

【 html+css 绚丽Loading 】000030 灵文闪烁符

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享htmlcss 绚丽Loading&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495…

【C++】继承相关知识详细梳理

1.继承简介 什么是继承&#xff1a; 继承(inheritance)机制是面向对象程序设计使代码可以复用的最重要的手段&#xff0c;它允许程序员在保持原有类特性的基础上进行扩展&#xff0c;增加功能&#xff0c;这样产生新的类&#xff0c;称派生类。 继承呈现了面向对象程序设计的层…

python破解[5分钟解决拼多多商家后台字体加密]

可【QQ群】拿源码 进入经营总览想把数据存下来发现返回的json数据部分空白如下 这可怎么办 稳住应该是字体的问题&#xff0c;可能是多多自己实现了某种字体&#xff0c;我们去找他的js 发现如我们所想&#xff0c;进行跟踪&#xff0c;发现的确是在css端进行了字体替换&am…