• 学习:jxl读写Excel


    最近和Excel频繁亲密接触,主要将N个Excel表中的数据拷贝到另外的Excel 表中规整为二维结构以便入库。但是有些表存在合并单元格的情况,甚是恼火,怎么办哪?好在这N个Excel表结构还比较一致,可以写程序在指定位置读取, 然后再写入到新的Excel表中,这样就OK了。这里面主要用到一个组件JXL.

    jxl的安装:
    主要就是将jxl的包放在WEB-INF的classes下面(如果下载到的是.jar文件,就放在lib下面).别忘了将jxl包中的common文件夹也放在WEB-INF下面.

    jxl的使用:
    主要的功能就是读Excel文件和写Excel文件

    <b>读:</b>
    读的时候是这样的一个思路,先用一个输入流(InputStream)得到Excel文件,然后用jxl中的Workbook得到工作薄,用Sheet从工作薄中得到工作表,用Cell得到工作表中得某个单元格.
    InputStream->Workbook->Sheet->Cell,就得到了excel文件中的单元格

    代码:
    <%@ page contentType="text/html; charset=gb2312" %>
    <%@  page  import="java.io.*,jxl.*,jxl.write.*,jxl.write.*,jxl.format.*"  %> 
    String path="c:\\excel.xls";//Excel文件URL
    InputStream is = new FileInputStream(path);//写入到FileInputStream
    jxl.Workbook wb = Workbook.getWorkbook(is); //得到工作薄     
    jxl.Sheet st = wb.getSheet(0);//得到工作薄中的第一个工作表
    Cell cell=st.getCell(0,0);//得到工作表的第一个单元格,即A1
    String content=cell.getContents();//getContents()将Cell中的字符转为字符串
    wb.close();//关闭工作薄
    is.close();//关闭输入流


    我们可以通过Sheet的getCell(x,y)方法得到任意一个单元格,x,y和excel中的坐标对应.
    例如A1对应(0,0),A2对应(0,1),D3对应(3,2).Excel中坐标从A,1开始,jxl中全部是从0开始.
    还可以通过Sheet的getRows(),getColumns()方法得到行数列数,并用于循环控制,输出一个sheet中的所有内容.

    <b>写:</b>
    往Excel中写入内容主要是用jxl.write包中的类.
    思路是这样的:
    OutputStream<-WritableWorkbook<-WritableSheet<-Label
    这里面Label代表的是写入Sheet的Cell位置及内容.
    代码:

    <%@ page contentType="text/html; charset=gb2312" %>
    <%@  page  import="java.io.*,jxl.*,jxl.write.*,jxl.write.*,jxl.format.*"  %>
    OutputStream os=new  FileOutputStream("c:\\test.xls");//输出的Excel文件URL
    WritableWorkbook wwb = Workbook.createWorkbook(os);//创建可写工作薄
    WritableSheet ws = wwb.createSheet("sheet1", 0);//创建可写工作表
    Label labelCF=new Label(0, 0, "hello");//创建写入位置和内容
    ws.addCell(labelCF);//将Label写入sheet中

    Label的构造函数Label(int x, int y,String aString)xy意同读的时候的xy,aString是写入的内容.

    WritableFont wf = new WritableFont(WritableFont.TIMES, 12, WritableFont.BOLD, false);//设置写入字体
    WritableCellFormat wcfF = new WritableCellFormat(wf);//设置CellFormat
    Label labelCF=new Label(0, 0, "hello");//创建写入位置,内容和格式

    Label的另一构造函数Label(int c, int r, String cont, CellFormat st)可以对写入内容进行格式化,设置字体及其它的属性.

    现在可以写了
    wwb.write();
    写完后关闭
    wwb.close();
    输出流也关闭吧
    os.close;

    OK,只要把读和写结合起来,就可以在N个Excel中读取数据写入你希望的Excel新表中,还是比较方便的.

  • 相关阅读:
    参考vue.js实现双向绑定的方法理解双向绑定原理(:Object.defineProperty和发布-订阅模式)
    不错的站点 博文
    使用C#动态生成Word文档/Excel文档的程序测试通过后,部署到IIS服务器上,不能正常使用的问题解决方案
    详解HTML<head> 头标签元素的意义以及使用场景
    css奇特用法之 IMG添加背景图片配合显示--效果惊艳
    .net面试题-15k+左右
    微信小程序IOS真机调试发生了SSL 错误,无法建立与该服务器的安全连接
    微信小程序自定义组件-下拉框
    微信小程序语音(A)发给别人(B),也能播放,是需要先把语音上传到自己的服务器上才可以
    微信小程序循环中点击一个元素,其他的元素不发生变化,类似点击一个循环中的语音,其他的不发生点击事件
  • 原文地址:https://www.cnblogs.com/forlina/p/2080601.html
Copyright © 2020-2023  润新知