java的poi技术读取和导入Excel实例

报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用性,不方便用户进行个性化编辑。Java程序由于其跨平台特性,不能直接操纵Excel。因此,本文探讨一下POI视线Java程序进行Excel的读取和导入。

项目结构:
java_poi_excel

用到的Excel文件:
xls

XlsMain .java 类

//该类有main方法,主要负责运行程序,同时该类中也包含了用poi读取Excel(2003版)

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

/**
 *
 * @author Hongten</br>
 *
 *
 */
public class XlsMain {

  public static void main(String[] args) throws IOException {
    XlsMain xlsMain = new XlsMain();
    XlsDto xls = null;
    List<XlsDto> list = xlsMain.readXls();

    try {
      XlsDto2Excel.xlsDto2Excel(list);
    } catch (Exception e) {
      e.printStackTrace();
    }
    for (int i = 0; i < list.size(); i++) {
      xls = (XlsDto) list.get(i);
      System.out.println(xls.getXh() + "  " + xls.getXm() + "  "
          + xls.getYxsmc() + "  " + xls.getKcm() + "  "
          + xls.getCj());
    }

  }

  /**
   * 读取xls文件内容
   *
   * @return List<XlsDto>对象
   * @throws IOException
   *       输入/输出(i/o)异常
   */
  private List<XlsDto> readXls() throws IOException {
    InputStream is = new FileInputStream("pldrxkxxmb.xls");
    HSSFWorkbook hssfWorkbook = new HSSFWorkbook(is);
    XlsDto xlsDto = null;
    List<XlsDto> list = new ArrayList<XlsDto>();
    // 循环工作表Sheet
    for (int numSheet = 0; numSheet < hssfWorkbook.getNumberOfSheets(); numSheet++) {
      HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(numSheet);
      if (hssfSheet == null) {
        continue;
      }
      // 循环行Row
      for (int rowNum = 1; rowNum <= hssfSheet.getLastRowNum(); rowNum++) {
        HSSFRow hssfRow = hssfSheet.getRow(rowNum);
        if (hssfRow == null) {
          continue;
        }
        xlsDto = new XlsDto();
        // 循环列Cell
        // 0学号 1姓名 2学院 3课程名 4 成绩
        // for (int cellNum = 0; cellNum <=4; cellNum++) {
        HSSFCell xh = hssfRow.getCell(0);
        if (xh == null) {
          continue;
        }
        xlsDto.setXh(getValue(xh));
        HSSFCell xm = hssfRow.getCell(1);
        if (xm == null) {
          continue;
        }
        xlsDto.setXm(getValue(xm));
        HSSFCell yxsmc = hssfRow.getCell(2);
        if (yxsmc == null) {
          continue;
        }
        xlsDto.setYxsmc(getValue(yxsmc));
        HSSFCell kcm = hssfRow.getCell(3);
        if (kcm == null) {
          continue;
        }
        xlsDto.setKcm(getValue(kcm));
        HSSFCell cj = hssfRow.getCell(4);
        if (cj == null) {
          continue;
        }
        xlsDto.setCj(Float.parseFloat(getValue(cj)));
        list.add(xlsDto);
      }
    }
    return list;
  }

  /**
   * 得到Excel表中的值
   *
   * @param hssfCell
   *      Excel中的每一个格子
   * @return Excel中每一个格子中的值
   */
  @SuppressWarnings("static-access")
  private String getValue(HSSFCell hssfCell) {
    if (hssfCell.getCellType() == hssfCell.CELL_TYPE_BOOLEAN) {
      // 返回布尔类型的值
      return String.valueOf(hssfCell.getBooleanCellValue());
    } else if (hssfCell.getCellType() == hssfCell.CELL_TYPE_NUMERIC) {
      // 返回数值类型的值
      return String.valueOf(hssfCell.getNumericCellValue());
    } else {
      // 返回字符串类型的值
      return String.valueOf(hssfCell.getStringCellValue());
    }
  }

}

XlsDto2Excel.java类

//该类主要负责向Excel(2003版)中插入数据

import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class XlsDto2Excel {

  /**
   *
   * @param xls
   *      XlsDto实体类的一个对象
   * @throws Exception
   *       在导入Excel的过程中抛出异常
   */
  public static void xlsDto2Excel(List<XlsDto> xls) throws Exception {
    // 获取总列数
    int CountColumnNum = xls.size();
    // 创建Excel文档
    HSSFWorkbook hwb = new HSSFWorkbook();
    XlsDto xlsDto = null;
    // sheet 对应一个工作页
    HSSFSheet sheet = hwb.createSheet("pldrxkxxmb");
    HSSFRow firstrow = sheet.createRow(0); // 下标为0的行开始
    HSSFCell[] firstcell = new HSSFCell[CountColumnNum];
    String[] names = new String[CountColumnNum];
    names[0] = "学号";
    names[1] = "姓名";
    names[2] = "学院";
    names[3] = "课程名";
    names[4] = "成绩";
    for (int j = 0; j < CountColumnNum; j++) {
      firstcell[j] = firstrow.createCell(j);
      firstcell[j].setCellValue(new HSSFRichTextString(names[j]));
    }
    for (int i = 0; i < xls.size(); i++) {
      // 创建一行
      HSSFRow row = sheet.createRow(i + 1);
      // 得到要插入的每一条记录
      xlsDto = xls.get(i);
      for (int colu = 0; colu <= 4; colu++) {
        // 在一行内循环
        HSSFCell xh = row.createCell(0);
        xh.setCellValue(xlsDto.getXh());
        HSSFCell xm = row.createCell(1);
        xm.setCellValue(xlsDto.getXm());
        HSSFCell yxsmc = row.createCell(2);
        yxsmc.setCellValue(xlsDto.getYxsmc());
        HSSFCell kcm = row.createCell(3);
        kcm.setCellValue(xlsDto.getKcm());
        HSSFCell cj = row.createCell(4);
        cj.setCellValue(xlsDto.getCj());
(xlsDto.getMessage());
      }
    }
    // 创建文件输出流,准备输出电子表格
    OutputStream out = new FileOutputStream("POI2Excel/pldrxkxxmb.xls");
    hwb.write(out);
    out.close();
    System.out.println("数据库导出成功");
  }

}

XlsDto .java类

//该类是一个实体类

public class XlsDto {
  /**
   * 选课号
   */
  private Integer xkh;
  /**
   * 学号
   */
  private String xh;
  /**
   * 姓名
   */
  private String xm;
  /**
   * 学院
   */
  private String yxsmc;
  /**
   * 课程号
   */
  private Integer kch;
  /**
   * 课程名
   */
  private String kcm;
  /**
   * 成绩
   */
  private float cj;
  public Integer getXkh() {
    return xkh;
  }
  public void setXkh(Integer xkh) {
    this.xkh = xkh;
  }
  public String getXh() {
    return xh;
  }
  public void setXh(String xh) {
    this.xh = xh;
  }
  public String getXm() {
    return xm;
  }
  public void setXm(String xm) {
    this.xm = xm;
  }
  public String getYxsmc() {
    return yxsmc;
  }
  public void setYxsmc(String yxsmc) {
    this.yxsmc = yxsmc;
  }
  public Integer getKch() {
    return kch;
  }
  public void setKch(Integer kch) {
    this.kch = kch;
  }
  public String getKcm() {
    return kcm;
  }
  public void setKcm(String kcm) {
    this.kcm = kcm;
  }
  public float getCj() {
    return cj;
  }
  public void setCj(float cj) {
    this.cj = cj;
  }

}

后台输出:

数据库导出成功

1.0    hongten    信息技术学院    计算机网络应用基础    80.0
2.0    王五    信息技术学院    计算机网络应用基础    81.0
3.0    李胜基    信息技术学院    计算机网络应用基础    82.0
4.0    五班古    信息技术学院    计算机网络应用基础    83.0
5.0    蔡诗芸    信息技术学院    计算机网络应用基础    84.0

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • java使用poi读取ppt文件和poi读取excel、word示例

    Apache的POI项目可以用来处理MS Office文档,codeplex上还有一个它的.net版本.POI项目可创建和维护操作各种基于OOXML和OLE2文件格式的Java API.大多数MS Office都是OLE2格式的.POI通HSMF子项目来支持Outlook,通过HDGF子项目来支持Visio,通过HPBF子项目来支持Publisher. 使用POI抽取Word简单示例: 要引入poi-3.7.jat和poi-scratchpad-3.7.ajr这两个包. 复制代码 代码如下: p

  • Java 使用poi把数据库中数据导入Excel的解决方法

    Java 利用poi把数据库中数据导入Excel 效果: 使用时先把poi包导入工程的path,注意只需要导入poi包即可,下载后有三个jar包 核心代码: 连接数据库:DBConnection.java 复制代码 代码如下: package org.xg.db;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;i

  • Java利用POI实现导入导出Excel表格示例代码

    介绍 Jakarta POI 是一套用于访问微软格式文档的Java API.Jakarta POI有很多组件组成,其中有用于操作Excel格式文件的HSSF和用于操作Word的HWPF,在各种组件中目前只有用于操作Excel的HSSF相对成熟.官方主页http://poi.apache.org/index.html,API文档http://poi.apache.org/apidocs/index.html 实现 已经在代码中加入了完整的注释. import java.io.FileInputSt

  • Java使用poi操作excel实例解析

    本文实例为大家分享了Java使用poi操作excel的具体代码,供大家参考,具体内容如下 依赖poi的jar包,pom.xml配置如下: <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0h

  • JAVA使用POI获取Excel的列数与行数

    前言 报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用性,不方便用户进行个性化编辑.Java程序由于其跨平台特性,不能直接操纵Excel.因此,本文探讨一下POI视线Java程序进行Excel中列数和行数的读取. 方法如下 //获取指定行,索引从0开始 hssfRow=hssfSheet.getRow(1); //获取指定列,索引从0开始 hssfCell=hssfRow.getCell((short)6); //获取总行数 //int rowNum=hssfSheet.ge

  • java使用poi读取excel内容方法实例

    复制代码 代码如下: import java.io.BufferedInputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import java.nio.channels.FileChannel;import java.text.DecimalFormat;import java.text.SimpleDat

  • java poi读取excel操作示例(2个代码)

    项目中要求读取excel文件内容,并将其转化为xml格式.常见读取excel文档一般使用POI和JExcelAPI这两个工具.这里我们介绍使用POI实现读取excel文档. 复制代码 代码如下: /* * 使用POI读取EXCEL文件 */import java.io.File;import java.io.FileInputStream;import java.util.ArrayList; import org.apache.poi.hssf.usermodel.HSSFCell;impor

  • 在java poi导入Excel通用工具类示例详解

    前言 本文主要给大家介绍了关于java poi导入Excel通用工具类的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 问题引入和分析 提示:如果不想看罗嗦的文章,可以直接到最后点击源码下载运行即可 最近在做一个导入Excel的功能,在做之前在百度上面查找"java通用导入Excel工具类",没有查到,大多数都是java通用导出Excel.后来仔细想想,导出可以利用java的反射,做成通用的,放进相应的实体成员变量中,导入为什么不可以呢?也是可以的,不过在做

  • java使用POI读取properties文件并写到Excel的方法

    本文实例讲述了java使用POI读取properties文件并写到Excel的方法.分享给大家供大家参考.具体实现方法如下: package com.hubberspot.code; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import

  • Java使用Apache POI库读取Excel表格文档的示例

    Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能. 项目下载页:http://poi.apache.org/download.html Apache POI 是创建和维护操作各种符合Office Open XML(OOXML)标准和微软的OLE 2复合文档格式(OLE2)的Java API.用它可以使用Java读取和创建,修改MS Excel文件.而且,还可以使用Jav

随机推荐