使用JXL创建Excel

jxl这个东西好久没使用了,时间长了,好多都忘记了。所以需要重新梳理下,其实主要就是创建各种各样的单元格,字符串、数字、日期、超链接、bool、字体、边框、背景……

废话不多说,代码才是王道。


   
import java.io.File; import java.io.IOException; import java.net.URL; import jxl.Workbook; import jxl.format.Alignment; import jxl.write.DateFormat; import jxl.write.DateTime; import jxl.write.Formula; import jxl.write.Label; import jxl.write.NumberFormat; import jxl.write.WritableCellFormat; import jxl.write.WritableFont; import jxl.write.WritableHyperlink; import jxl.write.WritableSheet; import jxl.write.WritableWorkbook; import jxl.write.WriteException; import jxl.write.biff.RowsExceededException; public class CreateExcel { public static void main(String[] args) { try { // 1.1 创建可写入的 Excel工作薄 WritableWorkbook writableWorkbook = Workbook .createWorkbook( new File( " test.xls " )); // 1.2 创建Excel工作表 WritableSheet writableSheet = writableWorkbook.createSheet( " sheet1 " , 0 ); // 2.1 添加Label对象 Label label00 = new Label( 0 , 0 , " 测试创建普通单元格label00 " ); writableSheet.addCell(label00); // 2.2 添加带有字体和边框的Formatting的对象 // 2.2.1 设置字体的大小、颜色等样式 WritableFont writableFont = new WritableFont(WritableFont.TIMES, 10 , WritableFont.BOLD, true ); WritableCellFormat writableCellFormat = new WritableCellFormat( writableFont); // 2.2.2 设置单元格的背景颜色 writableCellFormat.setBackground(jxl.format.Colour.GRAY_50); // 2.2.3 设置单元格的边框 writableCellFormat.setBorder(jxl.format.Border.ALL, jxl.format.BorderLineStyle.THICK, jxl.format.Colour.RED); // 2.2.3 设置单元格中元素的对齐方式 writableCellFormat.setAlignment(Alignment.RIGHT); // 2.2.4 添加Label对象 Label label01 = new Label( 0 , 1 , " TIMES " , writableCellFormat); writableSheet.addCell(label01); // 2.3.1 添加Number对象 jxl.write.Number label02 = new jxl.write.Number( 0 , 2 , 3.1415926 ); writableSheet.addCell(label02); // 2.3.2 添加带有formatting的 Number对象 NumberFormat numberFormat = new NumberFormat( " #.## " ); WritableCellFormat writableCellFormat4NumBer = new WritableCellFormat( numberFormat); jxl.write.Number label12 = new jxl.write.Number( 1 , 2 , 3.1415926 , writableCellFormat4NumBer); writableSheet.addCell(label12); // 2.4 添加Boolean对象 jxl.write.Boolean label03 = new jxl.write.Boolean( 0 , 3 , false ); jxl.write.Boolean label13 = new jxl.write.Boolean( 1 , 3 , true ); writableSheet.addCell(label03); writableSheet.addCell(label13); // 2.5.1 添加DateTime对象 DateTime label04 = new DateTime( 0 , 4 , new java.util.Date()); writableSheet.addCell(label04); // 2.5.2 添加带有formatting的DateFormat对象 DateFormat dateFormat = new DateFormat( " dd MM yyyy hh:mm:ss " ); WritableCellFormat writableCellFormat4DateTime = new WritableCellFormat( dateFormat); DateTime label05 = new DateTime( 1 , 4 , new java.util.Date(), writableCellFormat4DateTime); writableSheet.addCell(label05); // 2.6 添加WritableHyperlink对象 WritableHyperlink writableHyperlink = new WritableHyperlink( 0 , 5 , new URL( " http://my.oschina.net/wbw/blog " )); writableSheet.addHyperlink(writableHyperlink); // 2.7 添加Formual对象 Formula formula = new Formula( 0 , 6 , " CONCATENATE(A1,A2,A3) " ); writableSheet.addCell(formula); // 3.1 写入Exel工作表 writableWorkbook.write(); // 4.1 关闭Excel工作薄对象 writableWorkbook.close(); } catch (IOException e) { e.printStackTrace(); } catch (RowsExceededException e) { e.printStackTrace(); } catch (WriteException e) { e.printStackTrace(); } } }

转载于:https://my.oschina.net/wbw/blog/222171

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值