当前位置: 首页 > article >正文

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

}

写入excel结果


http://www.kler.cn/a/287091.html

相关文章:

  • 基础jjj
  • BH1750使用程序
  • HTML<img>标签
  • 一次理清楚Java中的日期和时间
  • [深度学习]机器学习和深度学习
  • 从零开始:Spring Boot核心概念与架构解析
  • 华为OD机试(C卷,100分)- 字符串排序
  • 《JavaEE进阶》----5.<SpringMVC②剩余基本操作(CookieSessionHeader响应)>
  • 自己开发完整项目一、登录功能-03(使用springSecurity安全框架,查询用户角色权限)
  • fabricjs 完成橡皮擦
  • 艾瑞白皮书解读(四)丨深度解析企业数据治理第一步:咨询环节
  • 【解决】CentOS7 生命周期结束后 使用 yum命令报错问题
  • assert()在solidity的运用,模糊测试案例
  • 【C++】vector(下)--下篇
  • prometheus基于文件的服务发现
  • 百日草花语探秘:天长地久的情感寄托与丰富内涵解析
  • 基于Virtex UltraScale+ VU13P FPGA的4路FMC接口基带信号处理平台
  • Python测试之测试覆盖率统计
  • Linux:SQLite 数据库
  • 安卓13 鼠标右键作返回键,鼠标事件修改
  • Vidda电视X Ultra等加入能效补贴,京东天猫可买量大管饱
  • 【验证码逆向专栏】某某滑块逆向分析
  • Java常见设计模式
  • 第二证券:三大因素将共同推动悲观情绪修复 风格阶段性趋于平衡
  • 【算法】二分查找
  • ARM32开发——(二十一)ADC系统工作原理