|
使用该API非Windows操作系统也可以通过纯Java应用来处理Excel数据表。因为是使用 Java编写的,所以我们在Web应用中可以通过JSP、Servlet来调用API实现对Excel数据表的访问。
复制代码 代码如下: package com.yonyou.test;
import java.io.File; import java.io.IOException;
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.write.Label; import jxl.write.NumberFormats; import jxl.write.WritableCellFormat; import jxl.write.WritableFont; import jxl.write.WritableSheet; import jxl.write.WritableWorkbook; import jxl.write.WriteException; import jxl.write.biff.RowsExceededException;
public class JxlTable {
private final static JxlTable jxlTable = new JxlTable();
public static JxlTable getInstance() { return jxlTable; }
public JxlTable() { }
public boolean createTable(String header,String[] body,String filePath) { boolean createFlag = true; WritableWorkbook book; try { // 根据路径生成excel文件 book = Workbook.createWorkbook(new File(filePath)); // 创建一个sheet名为"表格" WritableSheet sheet = book.createSheet("表格",0); // 设置NO列宽度 sheet.setColumnView(1,5); // 去掉整个sheet中的网格线 sheet.getSettings().setShowGridLines(false); Label tempLabel = null; // 表头输出 String[] headerArr = header.split(","); int headerLen = headerArr.length; // 循环写入表头内容 for (int i = 0; i < headerLen; i++) { tempLabel = new Label(1 + i,1,headerArr[i], getHeaderCellStyle()); sheet.addCell(tempLabel); } // 表体输出 int bodyLen = body.length; // 循环写入表体内容 for (int j = 0; j < bodyLen; j++) { String[] bodyTempArr = body[j].split(","); for (int k = 0; k < bodyTempArr.length; k++) { WritableCellFormat tempCellFormat = null; tempCellFormat = getBodyCellStyle(); if (tempCellFormat != null) { if (k == 0 || k == (bodyTempArr.length - 1)) { tempCellFormat.setAlignment(Alignment.CENTRE); } } tempLabel = new Label(1 + k,2 + j,bodyTempArr[k], tempCellFormat); sheet.addCell(tempLabel); } } book.write(); book.close(); } catch (IOException e) { createFlag = false; System.out.println("EXCEL创建失败!"); e.printStackTrace(); } catch (RowsExceededException e) { createFlag = false; System.out.println("EXCEL单元设置创建失败!"); e.printStackTrace(); } catch (WriteException e) { createFlag = false; System.out.println("EXCEL写入失败!"); e.printStackTrace(); }
return createFlag; }
public WritableCellFormat getHeaderCellStyle() { WritableFont font = new WritableFont(WritableFont.createFont("宋体"),10, WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE); WritableCellFormat headerFormat = new WritableCellFormat( NumberFormats.TEXT); try { // 添加字体设置 headerFormat.setFont(font); // 设置单元格背景色:表头为黄色 headerFormat.setBackground(Colour.YELLOW); // 设置表头表格边框样式 // 整个表格线为粗线、黑色 headerFormat.setBorder(Border.ALL,BorderLineStyle.THICK, Colour.BLACK); // 表头内容水平居中显示 headerFormat.setAlignment(Alignment.CENTRE); } catch (WriteException e) { System.out.println("表头单元格样式设置失败!"); } return headerFormat; }
public WritableCellFormat getBodyCellStyle() { WritableFont font = new WritableFont(WritableFont.createFont("宋体"), WritableFont.NO_BOLD,UnderlineStyle.NO_UNDERLINE); WritableCellFormat bodyFormat = new WritableCellFormat(font); try { // 设置单元格背景色:表体为白色 bodyFormat.setBackground(Colour.WHITE); // 设置表头表格边框样式 // 整个表格线为细线、黑色 bodyFormat .setBorder(Border.ALL,BorderLineStyle.THIN,Colour.BLACK); } catch (WriteException e) { System.out.println("表体单元格样式设置失败!"); } return bodyFormat; }
public static void main(String[] args) { String header = "NO,姓名,性别,年龄"; String[] body = new String[4]; body[0] = "1,欧阳锋,男,68"; body[1] = "2,黄药师,67"; body[2] = "3,洪七公,70"; body[3] = "4,郭靖,32"; String filePath = "e:/test.xls"; JxlTable testJxl = JxlTable.getInstance(); boolean flag = testJxl.createTable(header,body,filePath); if (flag) { System.out.println("表格创建成功!!"); } } }
分步讲解:
读取excel文件
要读取excel文件首先应该建立一个wordbook: 复制代码 代码如下: Workbook wb=Workbook.getWorkbook(File file); Workbook wb=Workbook.getWorkbook(InputStream is);
然后就可以获得它的工作表: 复制代码 代码如下: Sheet[] sheets=wb.getSheets(); //获得所有工作表 Sheet sheet=wb.getSheet(0); //表示获得第一个工作表。
最后就可以获得对某工作表的某些单元格的值: 复制代码 代码如下: Cell cell=sheet.getCell(0,0); //获得第一列 第一行的数据。第一个参数为列 String value=cell.getContents(); //获得该单元格的字符串形式的值 String type=cell.getType(); //获得该单元格的数据类型。
关闭workbook工作流: 当你完成对Excel电子表格数据的处理后,一定要使用close()方法来关闭先前创建的对象,以释放读取数据表的 过程中所占用的内存空间,在读取大量数据时显得尤为重要。参考如下代码片段: 复制代码 代码如下: wb.close();
注意:只有完成对该excel的操作后才可以关闭,关闭后在调用如Sheet s=wb.getSheet(0)会为null的。
常用的方法介绍:
Workbook类提供的方法 1. int getNumberOfSheets() 获得工作薄(Workbook)中工作表(Sheet)的个数,示例: 复制代码 代码如下: jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile)); int sheets = rwb.getNumberOfSheets();
2. Sheet[] getSheets() 返回工作薄(Workbook)中工作表(Sheet)对象数组,示例: 复制代码 代码如下: jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile)); Sheet[] sheets = rwb.getSheets();
Sheet接口提供的方法
1. String getName() 获取Sheet的名称,示例: 复制代码 代码如下: jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile)); jxl.Sheet rs = rwb.getSheet(0); String sheetName = rs.getName();
2. int getColumns() 获取Sheet表中所包含的总列数,示例: 复制代码 代码如下: jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile)); jxl.Sheet rs = rwb.getSheet(0); int rsColumns = rs.getColumns();
3. Cell[] getColumn(int column) 获取某一列的所有单元格,返回的是单元格对象数组,示例: 复制代码 代码如下: jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile)); jxl.Sheet rs = rwb.getSheet(0); Cell[] cell = rs.getColumn(0);
4. int getRows() 获取Sheet表中所包含的总行数,示例: 复制代码 代码如下: jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile)); jxl.Sheet rs = rwb.getSheet(0); int rsRows = rs.getRows();
5. Cell[] getRow(int row)
您可能感兴趣的文章:- Java读取Excel文件内容的简单实例
- Java数据导出功能之导出Excel文件实例
- java实现合并单元格的同时并导出excel示例
- java读取excel文件并复制(copy)文件到指定目录示例
- java常用工具类之Excel操作类及依赖包下载
- java实现excel导入数据的工具类
- JAVA使用POI获取Excel的列数与行数
- java poi读取excel操作示例(2个代码)
- Java实现操作excel表格
- 在java poi导入Excel通用工具类示例详解
- Java实现的Excel列号数字与字母互相转换功能
(编辑:安卓应用网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|