



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
java利用jxl工具包操作Excel文件2009-11-27 13:00简单讲解使用操作Excel的常用第三方工具包jxl来实现对Excel文件的读写。我们先看一下读的操作:Java代码 1. /* 2. * 读 3. * param file 欲读取的Excel文件的路径 4. * return 5. * throws Exception 6. */ 7. public static String read(File file) throws Exception 8. StringBuffer sb = new StringBuffer(); 9. 10. Workbook wb = null; 11. try 12. / 获取工作簿对象 13. wb = Workbook.getWorkbook(file); 14. if (wb != null) 15. / 获取工作簿对象就可以获取工作簿内的工作表对象 16. Sheet sheets = wb.getSheets(); 17. if (sheets != null & sheets.length != 0) 18. / 遍历工作簿内所有工作表 19. for (int i=0;isheets.length;i+) 20. / 获取该工作表内的行数 21. int rows = sheetsi.getRows(); 22. / 遍历行 23. for (int j=0;jrows;j+) 24. / 获取当前行的所有单元格 25. Cell cells = sheetsi.getRow(j); 26. if (cells != null & cells.length != 0) 27. / 遍历单元格 28. for (int k=0;kcells.length;k+) 29. / 获取当前单元格的值 30. String cell = cellsk.getContents(); 31. / 缩进 32. sb.append(cell + t); 33. 34. sb.append(tn); 35. 36. 37. sb.append(tn); 38. 39. 40. System.out.println(成功读取了: + file + n); 41. 42. catch (Exception e) 43. System.out.println(e.getMessage(); 44. finally 45. wb.close(); 46. 47. return sb.toString(); 48. /* * 读 * param file 欲读取的Excel文件的路径 * return * throws Exception */ public static String read(File file) throws Exception StringBuffer sb = new StringBuffer(); Workbook wb = null; try / 获取工作簿对象 wb = Workbook.getWorkbook(file); if (wb != null) / 获取工作簿对象就可以获取工作簿内的工作表对象 Sheet sheets = wb.getSheets(); if (sheets != null & sheets.length != 0) / 遍历工作簿内所有工作表 for (int i=0;isheets.length;i+) / 获取该工作表内的行数 int rows = sheetsi.getRows(); / 遍历行 for (int j=0;jrows;j+) / 获取当前行的所有单元格 Cell cells = sheetsi.getRow(j); if (cells != null & cells.length != 0) / 遍历单元格 for (int k=0;kcells.length;k+) / 获取当前单元格的值 String cell = cellsk.getContents(); / 缩进 sb.append(cell + t); sb.append(tn); sb.append(tn); System.out.println(成功读取了: + file + n); catch (Exception e) System.out.println(e.getMessage(); finally wb.close(); return sb.toString(); 方法的返回类型是一个String,我定义了一个StringBuffer对象,大家知道StringBuffer上的主要操作是 append 和 insert 方法,可以重载这些方法,以接受任意类型的数据。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符追加或插入到字符串缓冲区中。append 方法始终将这些字符添加到缓冲区的末端,这样的话我们在接受返回值的时候就可以方便的取到被转换成String类型的数据了。首先我们通过传入的欲读取文件路径,获取工作簿对象,获取工作簿对象之后,我们就可以轻而易举的取到该工作簿内的所有的工作表了,我们声明一个工作表类型的数组:Sheet sheets = wb.getSheets()以便遍历得到每个工作表内的行数,之后就是行内的单元格,单元格再到单元格内的值,整个步骤都是按从大到小的顺利来的,可以说一气呵成,短短的几个循环,搞定。接下来我们看写的操作:Java代码 1. /* 2. * 写 3. * param fileName 被写入的Excel文件的路径 4. * param sheetName 被写入的Excel文件的工作表 5. * param location 被写入的Excel文件的工作表位于工作簿的位置 6. * throws Exception 7. */ 8. public static void write(String fileName, String sheetName, int location) throws Exception 9. WritableWorkbook wwb = null; 10. Label label = null; 11. 12. try 13. / 创建可写入的工作簿对象 14. wwb = Workbook.createWorkbook(new File(fileName); 15. if (wwb != null) 16. / 在工作簿里创建可写入的工作表,第一个参数为工作表名,第二个参数为该工作表的所在位置 17. WritableSheet ws = wwb.createSheet(sheetName, location); 18. if (ws != null) 19. /* 添加表结构 */ 20. / 行 21. for (int i=0;i5;i+) 22. / 列 23. for (int j=0;j5;j+) 24. / Label构造器中有三个参数,第一个为列,第二个为行,第三个则为单元格填充的内容 25. label = new Label(j, i, 第+(i+1)+行, + 第+(j+1)+列); 26. / 将被写入数据的单元格添加到工作表 27. ws.addCell(label); 28. 29. 30. / 从内存中写入到文件 31. wwb.write(); 32. 33. System.out.println(路径为: + fileName + 的工作簿写入数据成功!); 34. 35. catch (Exception e) 36. System.out.println(e.getMessage(); 37. finally 38. wwb.close(); 39. 40. /* * 写 * param fileName 被写入的Excel文件的路径 * param sheetName 被写入的Excel文件的工作表 * param location 被写入的Excel文件的工作表位于工作簿的位置 * throws Exception */ public static void write(String fileName, String sheetName, int location) throws Exception WritableWorkbook wwb = null; Label label = null; try / 创建可写入的工作簿对象 wwb = Workbook.createWorkbook(new File(fileName); if (wwb != null) / 在工作簿里创建可写入的工作表,第一个参数为工作表名,第二个参数为该工作表的所在位置 WritableSheet ws = wwb.createSheet(sheetName, location); if (ws != null) /* 添加表结构 */ / 行 for (int i=0;i5;i+) / 列 for (int j=0;j5;j+) / Label构造器中有三个参数,第一个为列,第二个为行,第三个则为单元格填充的内容 label = new Label(j, i, 第+(i+1)+行, + 第+(j+1)+列); / 将被写入数据的单元格添加到工作表 ws.addCell(label); / 从内存中写入到文件 wwb.write(); System.out.println(路径为: + fileName + 的工作簿写入数据成功!); catch (Exception e) System.out.println(e.getMessage(); finally wwb.close(); 我们看到在方法首行定义了一个WritableWorkbook 对象,WritableWorkbook 实际上就是一个写工作簿对象,同样我们要先获取一个工作簿,传入的文件路径,将欲读取的文件赋给WritableWorkbook 对象,这样我们就可以获取工作簿内的工作表了,得到工作表就好办了,我们通过调用WritableWorkbook 对象的createSheet()方法,传入工作表名和该表的所在位置,成功得到工作表后就开始在该工作表内添加表结构,这里我写的是五行五列,可以根据自己的实际要求改一下就OK,那么Label是一个什么东西呢?Label实际上就是一个填充单元格的对象,通过指定的行和列及需要填充的内容,最后将被写入数据的单元格添加到工作表中就大功告成了。最后一步调用WritableWorkbook 的write()方法将写入内存的数据写入到文件即可。Over!下面是测试类:Java代码 1. package org.yt.jxl.excelDemo; 2. 3. import java.io.File; 4. 5. import jxl.Cell; 6. import jxl.Sheet; 7. import jxl.Workbook; 8. import jxl.write.Label; 9. import jxl.write.WritableSheet; 10. import jxl.write.WritableWorkbook; 11. 12. /* 13. * 执行对Excel文件的读写操作 14. * author 袁通 15. */ 16. public class ExcelDemo 17. public static void main(String args) 18. /* 测试读取(注意:文件路径中的盘符D:/,注意斜杠不要写成反斜杠) */ 19. / 如果不存在该文件,返回空并抛出异常 20. /*File file = new File(D:/testRead.xls); 21. try 22. System.out.println(read(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年新饭店简单合伙协议书
- 科技业务合作协议书模板
- 租房子业主终止合同协议
- 2025年新用地合同解除协议书
- 2025贵州施秉县人民医院招聘17人备考题库及答案解析
- 2025广东清远市连南瑶族自治县香坪镇选拔村党组织书记助理1人笔试模拟试题及答案解析
- 医学研究赞助协议书范本
- 教育机构转让费合同范本
- 2025安康汉阴县社区工作者招聘(20人)笔试模拟试题及答案解析
- 租房合同涨房租补充协议
- 法律法规培训
- 从邵逸夫医院看大型三甲医院医疗信息化多层设计与实践
- 心理韧性培育培训
- 实验室危险化学品安全培训
- 肿瘤二代测序基因检测技术应用与进展
- 上海同济医院管理制度
- 2025年高考北京卷语文真题作文记叙文深度点评与分析
- 小学生队形队列班会课件
- 地中海贫血护理业务查房
- 华科版七年级信息技术《身边信息-用心感知》
- 职业技术学院运动健康指导专业人才培养方案
评论
0/150
提交评论