使用Apache POI创建Excel,并从数据库中读取数据写入到Excel文件中

使用Apache POI创建Excel,并从数据库中读取数据写入到Excel文件中

摘要: 介绍:Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能。   结构:HSSF - 提供读写Microsoft Excel格式档案的功能。XSSF - 提供 ...
 介绍:
    Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能。
  结构:
  HSSF - 提供读写Microsoft Excel格式档案的功能。
  XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。
  HWPF - 提供读写Microsoft Word格式档案的功能。
  HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
  HDGF - 提供读写Microsoft Visio格式档案的功能。
   详情: http://poi.apache.org/
步骤:

数据库字段

 

 

创建一个连接数据库(UtilsUtils.java)

 

pacukage org.html.model;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Utils {

 private static Connection con;
 private static String Driver ="com.mysql.jdbc.Driver";
 private static String url ="jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=utf8";
 private static String username ="root";
 private static String password ="123";

 public static Connection getConnection(){

  try {
   Class.forName(Driver);

   con =DriverManager.getConnection(url,username,password);

  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  return con;
 }

 public static void closeDB(ResultSet rs ,Statement st ,Connection con){
  try {
   if(rs !=null){
    rs.close();
    rs =null;
   }
   if(st !=null){
    st.close();
    st =null;
   }
   if(con !=null){
    con.close();
    con =null;
   }
  } catch (SQLException e) {
   e.printStackTrace();
  }
  
 }
}

 

 

 

创建一个Model(PersonModel.java)

 

public class PersonModel {

 

 private int id ;
 private String name;
 
 public int getId() {
  return id;
 }
 public void setId(int id) {
  this.id = id;
 }
 public String getName() {
  return name;
 }
 public void setName(String name) {
  this.name = name;
 }
 
}

创建一个测试类(PersonDao.java)

package org.poi.excel.dao;

 

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
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;
import org.html.model.PersonModel;
import org.html.model.Utils;

public class PersonDao {
 
 public static List<PersonModel> QueryPerson(){
  Connection con =null;
  Statement st =null;
  ResultSet rs =null;

  String sql ="select * from persons";
  con =Utils.getConnection();
  List<PersonModel> list =new ArrayList<PersonModel>();
  
  try {
   st =con.createStatement();
   
   rs =st.executeQuery(sql);

   while(rs.next()){
    PersonModel model =new PersonModel();
    model.setId(rs.getInt(1));
    model.setName(rs.getString(2));

    list.add(model);
   }
  } catch (SQLException e) {
   e.printStackTrace();
  }finally{
   Utils.closeDB(rs, st, con);
  }
  return list;
 }
 
 public void CreateExcel(){
  
  //创建一个工作簿
  HSSFWorkbook workBook =new HSSFWorkbook();

  //创建一个工作表,名为:第一页
  HSSFSheet sheet =workBook.createSheet("第一页");
  
  //设置单元格的宽度(0:表示第一行的第一个单元格,1:第一行的第二个单元格)
  sheet.setColumnWidth((short)0, 2500);
  sheet.setColumnWidth((short)1, 5000);
  
  //创建一个单元格,从0开始
  HSSFRow row =sheet.createRow((short)0);

  //构造一个数组设置第一行之后的单元格
  HSSFCell cell[] =new HSSFCell[2];

  for(int i=0 ;i <2 ;i++){
   cell[i] =row.createCell(i);
  }
  cell[0].setCellValue("ID");
  cell[1].setCellValue("Name");
  
  //获得从数据库中查询出来的数据
  List<PersonModel> list=PersonDao.QueryPerson();
  
  if(list !=null && list.size() >0){
   
   //循环list中的数据
   for(int i =0;i<list.size();i++){

    PersonModel model =list.get(i);
    HSSFRow dataRow =sheet.createRow(i +1);
    HSSFCell data[] =new HSSFCell[2];

    for(int j= 0;j < 2 ; j++){
     data[j] =dataRow.createCell(j);
    }
    data[0].setCellValue(model.getId());
    data[1].setCellValue(model.getName());
    
    try {
     //输出成XLS文件
     File file =new File("D://person.xls");
     FileOutputStream fos = new FileOutputStream(file);

     //写入数据,并关闭文件
     workBook.write(fos);
     fos.close();
     
    /*
        //将工作薄输出到输出流
     ServletOutputStream sos =response.getOutputStream();
     workBook.write(sos);
     fos.close();
    */
    } catch (FileNotFoundException e) {
     e.printStackTrace();
    } catch (IOException e) {
     e.printStackTrace();
    }
   }
  }
 }
 
 public static void main(String args[]){
  //测试
  PersonDao dao =new PersonDao();
  dao.CreateExcel();
 }
}
package org.poi.excel.dao;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
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;
import org.html.model.PersonModel;
import org.html.model.Utils;

public class PersonDao {
 
 public static List<PersonModel> QueryPerson(){
  Connection con =null;
  Statement st =null;
  ResultSet rs =null;

  String sql ="select * from persons";
  con =Utils.getConnection();
  List<PersonModel> list =new ArrayList<PersonModel>();
  
  try {
   st =con.createStatement();
   
   rs =st.executeQuery(sql);

   while(rs.next()){
    PersonModel model =new PersonModel();
    model.setId(rs.getInt(1));
    model.setName(rs.getString(2));

    list.add(model);
   }
  } catch (SQLException e) {
   e.printStackTrace();
  }finally{
   Utils.closeDB(rs, st, con);
  }
  return list;
 }
 
 public void CreateExcel(){
  
  //创建一个工作簿
  HSSFWorkbook workBook =new HSSFWorkbook();

  //创建一个工作表,名为:第一页
  HSSFSheet sheet =workBook.createSheet("第一页");
  
  //设置单元格的宽度(0:表示第一行的第一个单元格,1:第一行的第二个单元格)
  sheet.setColumnWidth((short)0, 2500);
  sheet.setColumnWidth((short)1, 5000);
  
  //创建一个单元格,从0开始
  HSSFRow row =sheet.createRow((short)0);

  //构造一个数组设置第一行之后的单元格
  HSSFCell cell[] =new HSSFCell[2];

  for(int i=0 ;i <2 ;i++){
   cell[i] =row.createCell(i);
  }
  cell[0].setCellValue("ID");
  cell[1].setCellValue("Name");
  
  //获得从数据库中查询出来的数据
  List<PersonModel> list=PersonDao.QueryPerson();
  
  if(list !=null && list.size() >0){
   
   //循环list中的数据
   for(int i =0;i<list.size();i++){

    PersonModel model =list.get(i);
    HSSFRow dataRow =sheet.createRow(i +1);
    HSSFCell data[] =new HSSFCell[2];

    for(int j= 0;j < 2 ; j++){
     data[j] =dataRow.createCell(j);
    }
    data[0].setCellValue(model.getId());
    data[1].setCellValue(model.getName());
    
    try {
     //输出成XLS文件
     File file =new File("D://person.xls");
     FileOutputStream fos = new FileOutputStream(file);

     //写入数据,并关闭文件
     workBook.write(fos);
     fos.close();
     
    /*
        //将工作薄输出到输出流
     ServletOutputStream sos =response.getOutputStream();
     workBook.write(sos);
     fos.close();
    */
    } catch (FileNotFoundException e) {
     e.printStackTrace();
    } catch (IOException e) {
     e.printStackTrace();
    }
   }
  }
 }
 
 public static void main(String args[]){
  //测试
  PersonDao dao =new PersonDao();
  dao.CreateExcel();
 }
}

原文地址:http://www.189works.com/article-6712-1.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值