import java.io.File;
import java.io.IOException;

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;

/**
 *
 * @ClassName: ExcelOperate
 * @Description: TODO(使用jxl简单实现Excel导入导出)
 * @date 2016年8月3日 下午2:12:53
 *
 */

public class ExcelOperate {
    public static void main(String[] args) {
        //writeToFile();
//        /this.readFromFile();
    }
    int col=100,row =100;
    
    /**
     *
     * @Title: ExcelOperate
     * @Description: TODO(读取excel文件里的内容)
     * @param @param path    设定文件
     * @return @param path    返回类型
     * @throws
     */
    public boolean readExcel(String path){
        boolean flag=false;
        File file = new File(path);
//        File file = new File("C:/Users/Administrator/Desktop/mmonitor.xls");
        StringBuffer sb = new StringBuffer();
        try {
            Workbook book = Workbook.getWorkbook(file);//拿到excel工作空间
            try{
                Sheet sheet = book.getSheet(0);
                col = book.getSheet(0).getColumns();//获取excel文件有列
                row = book.getSheet(0).getRows();//获取excel文件有行
                System.out.println(col+"=="+row);
                for(int i = 1 ; i < col ; i++){
                    for(int j = 1 ; j <row ; j++){
                        //第一个参数代表列,第二个参数代表行。(默认起始值都为0)
                        try{
                            Cell jj =sheet.getCell(j, i);//获取excel单个格子
                            if(jj!=null){
                                String cont=jj.getContents();//获取格子的内容
                                sb.append(cont+"\t");
                                System.out.println(cont);
                            }
                        }catch(Exception e){
                            System.out.println("这个表格没有值");
                        }
                    }
                    sb.append("\n");
                }
                flag=true;
                //System.out.println(sb);
            }finally{
                if(book != null){
                    book.close();
                }
            }
        } catch (BiffException e) {
            System.err.println(e+"");
        } catch (IOException e) {
            System.err.println(e+"文件读取错误");
        }
        return flag;
    }//end readFromFile
    
    //witeToFile
    public  void writeToFile(){
        File file = new File("C:/Users/Administrator/Desktop/mmonitor.xls");
        try {
            
            WritableWorkbook book = Workbook.createWorkbook(file);
            //创建一个工作区。(默认的excel文件有三个sheet,在excel的左下角可以看到sheet1/sheet2/sheet3)
            WritableSheet sheet = book.createSheet("第一页", 0);
            //在工作区上面添加内容
            try {
                for(int i = 0; i < 10 ; i ++ ){
                    for(int j = 0 ; j < 10 ; j++){
                        Label newLabel;
                        if(0 == i){
                            //第一个参数代表列,第二个参数代表行(默认起始值都为0),第三个参数是要在单元格里面填写的内容发
                            newLabel = new Label(j,i,String.valueOf("的"));
                        }else if(0 == j){
                            newLabel = new Label(j,i,String.valueOf("的"));
                        }else{
                            newLabel = new Label(j,i,String.valueOf("的"));
                        }
                        //在单元格上面添加注释
//                        WritableCellFeatures cellFeatures = new WritableCellFeatures();
//                        cellFeatures.setComment("这里是"+i+"*"+j+"的值");
//                        System.out.println("这里是"+i+"*"+j+"的值");
//                        newLabel.setCellFeatures(cellFeatures);
                        sheet.addCell(newLabel);
                    }
                }
            } catch (RowsExceededException e) {
                System.err.println(e+"行或列参数错误!");
            } catch (WriteException e) {
                System.err.println(e+"写入失败");
            }finally{
                if(book != null){
                    book.write();
                    try {
                        book.close();
                    } catch (WriteException e) {
                        System.err.println(e+"文件关闭失败!");
                    }
                }
            }
            
        } catch (IOException e) {
            System.err.println(e+"创建文件失败!");
        }
    }
    
    
}

简单excel导入导出的更多相关文章

  1. 一个基于POI的通用excel导入导出工具类的简单实现及使用方法

    前言: 最近PM来了一个需求,简单来说就是在录入数据时一条一条插入到系统显得非常麻烦,让我实现一个直接通过excel导入的方法一次性录入所有数据.网上关于excel导入导出的例子很多,但大多相互借鉴. ...

  2. Mego(04) - NET简单实现EXCEL导入导出

    前言 相信做过信息系统的朋友都会遇到EXCEL导入导出的相关开发,做过不少EXCEL导入导出后总结起来大致有如下几种方式实现: ADO.NET的OldDb或ODBC连接EXCEL使用DataTable ...

  3. Excel导入导出工具(简单、好用且轻量级的海量Excel文件导入导出解决方案.)

    Excel导入导出工具(简单.好用且轻量级的海量Excel文件导入导出解决方案.) 置顶 2019-09-07 16:47:10 $9420 阅读数 261更多 分类专栏: java   版权声明:本 ...

  4. Excel导入导出的业务进化场景及组件化的设计方案(上)

    1:前言 看过我文章的网友们都知道,通常前言都是我用来打酱油扯点闲情的. 自从写了上面一篇文章之后,领导就找我谈话了,怕我有什么想不开. 所以上一篇的(下)篇,目前先不出来了,哪天我异地二次回忆的时候 ...

  5. 关于Excel导入导出的用例设计

    目前,为方便操作,很多系统都会增加批量导入导出的功能.文件导入导出一般格式都是excel.由于用户直接在excel在填写内容,无法控制填写的格 式,加上excel解析比较困难,所以一般涉及到excel ...

  6. Octopus——excel导入导出工具

    Octopus Octopus是一个简易的Excel导入导出工具.目前主要就两个功能: 导入:将excel中一行数据转换为指定的java对象,并通过指定的正则表达式检查合法性. 导出:按照给定的xml ...

  7. JeeSite中Excel导入导出

    在各种管理系统中,数据的导入导出是经常用到的功能,通常导入导出以Excel.CSV格式居多.如果是学习的过程中,最好是自己实现数据导入与导出的功能,然而在项目中,还是调用现成的功能比较好.近期一直使用 ...

  8. 土制Excel导入导出及相关问题探讨

    转载请注明出处https://www.cnblogs.com/funnyzpc/p/10392085.html 新的一年,又一个开始,不见收获,却见年龄,好一个猪年,待我先来一首里尔克的诗: < ...

  9. java jxl excel 导入导出的 总结(建立超链接,以及目录sheet的索引)

    最近项目要一个批量导出功能,而且要生成一个单独的sheet页,最后后面所有sheet的索引,并且可以点击进入连接.网上搜索了一下,找到一个方法,同时把相关的excel导入导出操作记录一下!以便以后使用 ...

随机推荐

  1. 你不知道的JavaScript-2.词法作用域

    考虑以下代码: function foo(a) { var b = a * 2; function bar(c) { console.log( a, b, c ); } bar( b * 3 ); } ...

  2. CentOS 7静默安装Oracle 11g R2数据库软件

    之前安装Oracle 11g R2数据库软件都是建立在图形界面上的,不过现在大部分服务器上都没有安装图形界面.图形界面安装较为方便,安装选项清晰,步骤明确,但Oracle还支持另一种安装方式,就是通过 ...

  3. nuxtjs中修改head及vuex的使用

    1.在之前vue项目中,我们如果需要改变每个页面的title,是需要在路由里配置meta然后通过路由守卫将每个页面的title替换掉,但是在nuxtjs中他提供了一个方法,直接在每个.vue的文件中使 ...

  4. 星型数据仓库olap工具kylin介绍和简单使用示例

    本文转载自:https://www.cnblogs.com/hsydj/p/4515057.html 星型数据仓库olap工具kylin介绍 星型数据仓库olap工具kylin介绍 数据仓库是目前企业 ...

  5. C#简单的九九乘法表

    for(int i=1;i<10;i++) { for(int j=1;j<=i;j++) { Console.Write("{0}*{1}={2}",j,i,i*j) ...

  6. 关于mysql触发器和存储过程的理解

    内容源自:一篇很棒的 MySQL 触发器学习教程 一.触发器概念 触发器(trigger):监视某种情况,并触发某种操作,它是提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊 ...

  7. SublimeText3安装Highlight插件

    本来机子上装的是版本3,试了试网上的教程,比如这个:http://qq920924960.blog.163.com/blog/static/221611034201411247318866/ 结果都不 ...

  8. SIP 编解码器

    编解码器,编码器 - 解码器的简称,做两个基本操作 - 首先,它将模拟语音信号转换为其等效数字形式,以便可以容易地发送. 此后,它将压缩的数字信号转换回其原始模拟形式,以便可以重放. 市场上有许多编解 ...

  9. css的再深入7(更新中···)

    1.transparent  透明的 2.placeholder  提示语 写页面 搞清结构层次, 保证模块化,让他们之间不能受到影响 (1) 元素性质 (2) 标准流 浮动带来的脱离文档流撑不起父级 ...

  10. 【C++】10.18日的C++笔记

    使用memset初始化一个类会导致类中的指针和虚函数表出现问题.相关链接 使用memset(a,1,sizeof(a))初始化a数组不会达到预期的效果,因为memset会把每个字节赋值为1就会变成16 ...