Java+Excel学习

转载 2006年06月22日 20:38:00

近两天研究查看了下Java+Excel的方法

首先需要到网上下个jxl.jar的包

我写的练习代码如下:(注意里面的图片替换成自己的就可以了)

import java.io.*;
import java.util.Random;
import java.util.Date;
import jxl.*;
import jxl.format.UnderlineStyle;
import jxl.write.*;
import jxl.write.Number;
import jxl.write.Boolean;
public class CreateXL
{
    public CreateXL()
    {
        
    }
    public static void main(String[] args)
    {
        //读Excel
        //CreateXL.readExcel("d:/abc.xls");
        
        //创建新的Excel
        CreateXL.writeExcel("d:/new.xls");
        
        //更新Excel
        CreateXL.updateExcel("d:/new.xls");
        
    }
    //jxl暂时不提供修改已经存在的数据表,这里通过一个小办法来达到这个目的,不适合大型数据更新!
    //这里是通过覆盖原文件来更新的.
    public static void updateExcel(String filePath)
    {
        try
        {
            Workbook rwb = Workbook.getWorkbook(new File(filePath));
            WritableWorkbook wwb = Workbook.createWorkbook(new File("d:/new.xls"),rwb);//copy
            WritableSheet ws = wwb.getSheet(0);
            WritableCell wc = ws.getWritableCell(0,0);
            //判断单元格的类型,做出相应的转换
            Label label = (Label)wc;
            label.setString("The value has been modified");
            wwb.write();
            wwb.close();
            rwb.close();
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
    }

    public static void writeExcel(String filePath)
    {
        try
        {
            //创建工作薄
            WritableWorkbook wwb = Workbook.createWorkbook(new File(filePath));
            
            //创建工作表
            WritableSheet ws = wwb.createSheet("Sheet1",0);
            //System.out.println("create ok!");
            
            //添加标签文本
            Random rnd=new Random((new Date()).getTime());
            int forNumber=rnd.nextInt(100);
            for(int i=0;i<forNumber;i++)
            {
                ws.addCell(new Number(rnd.nextInt(50),rnd.nextInt(50),rnd.nextInt(1000)));
            }
            
            //添加图片(注意此处jxl暂时只支持png格式的图片)
      //0,1分别代表x,y    2,5代表宽和高占的单元格数
      ws.addImage(new WritableImage(0,1,2,5,new File("png//cs.png")));
            
            wwb.write();
      wwb.close();
        }
        catch(Exception e)
        {
            System.out.println(e.toString());
        }
    }
    public static void readExcel(String filePath)
    {
        /**
         *后续考虑问题,比如Excel里面的图片以及其他数据类型的读取
         **/
        try
        {
            InputStream is=new FileInputStream(filePath);
            //声名一个工作薄
            Workbook rwb = Workbook.getWorkbook(is);
            
            //获得工作薄的个数
            //rwb.getNumberOfSheets();
                
            //在Excel文档中,第一张工作表的缺省索引是0
            Sheet st = rwb.getSheet("Sheet1");
            
            //通用的获取cell值的方式,getCell(int column, int row) 行和列
            int Rows=st.getRows();
            int Cols=st.getColumns();
            System.out.println("当前工作表的名字:"+st.getName());
            System.out.println("总行数:"+Rows);
            System.out.println("总列数:"+Cols);
        
            Cell c;
            for(int i=0;i<Cols;++i)
            {
                for(int j=0;j<Rows;++j)
                {
                    //getCell(Col,Row)获得单元格的值
                    System.out.print((st.getCell(i,j)).getContents()+"/t");
                }
                System.out.print("/n");
            }
            //操作完成时,关闭对象,释放占用的内存空间
            rwb.close();
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
    }
}

相关文章推荐

Java Excel API 学习文档

  • 2012-02-10 19:53
  • 13KB
  • 下载

JAVA Excel API学习案例

先贴代码吧,运行一下,看看效果,然后看看注释,再看看代码后面的基础介绍 创建一个新excel并写入数据: public static void myExcel2() throws IOExcept...

java操作Excel的工具—POI学习

对于一个程序员来说,文件操作是经常遇到的,尤其是对Excel文件的操作。 目前处理Excel的开源javaAPI主要有两种,一是Jxl(Java Excel API),Jxl只支持Excel2003以...

jxls读取模板导出Excel学习笔记

jxls读取模板导出Excel学习笔记​ jxls是一个简单的、轻量级的excel导出库,使用特定的标记在excel模板文件中来定义输出格式和布局。除此以外,java中成熟的excel导出工具有p...

java学习笔记-excel表格形式记录

序号 标签符号 描述 用法 类型 2 # python-单行注释 #coding: UTF-8 注释 3 '' '''或""" "...

[ExtJS5学习笔记]第三十四节 sencha extjs 5 grid表格之java后台导出excel

继上次使用js前端导出excel之后,还有一个主要大家比较关注的是后台实现导出excel,因为本人开发使用的java所以这里使用apache的开源项目poi进行后台excel的导出。本文目录 本文目录...

学习笔记---java操作Excel经验总结

public ExcelDemo{ public static void writeExcel(OutputStream os) throws Exception { Writable...

java导出excel--------自己学习使用

package com.sais.inkaNet.reportStatistics.operationBeanavior.service;import java.io.IOException;impo...
  • hs6823
  • hs6823
  • 2011-07-15 12:56
  • 4515

java_web 学习记录(七):jxl excel export(一)

按照一定格式导出数据

【Java学习20170413】Excel文件读写

Excel文件读取与写入 运用POI方式实现 package com.share.read; import java.io.FileInputStream; import java.io.IOExc...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)