使用Apache POI创建Excel,并从数据库中读取数据写入到Excel文件中
2010-12-01 16:28
1161 查看
介绍:
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)
package 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();
}
}
看看你的D盘下是否有一个person.xls文件,打开看一下,里面就是数据库里的数据。
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)
package 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)
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();
}
}
看看你的D盘下是否有一个person.xls文件,打开看一下,里面就是数据库里的数据。
相关文章推荐
- 使用Apache POI创建Excel,并从数据库中读取数据写入到Excel文件中
- 使用Apache POI创建Excel,并从数据库中读取数据写入到Excel文件中
- 使用Apache POI读取Excel文件,将读取的数据转换成json写入文本文件
- 使用PHPExcel读取写入Excel文件数据
- java使用poi把从数据库中取出的数据写入到excel文件中并保存到指定文件路径
- 使用jxl.jar处理excel文档,创建的excel文件不能写入数据
- poi 学习之使用 Apche poi 读取数据库中的数据并写入Excel
- 使用jxl读取模板文件,写入数据并导出excel
- SQLBulkCopy使用实例--读取Excel写入数据库/将 Excel 文件转成 DataTable
- 使用perl语言读数据库并将数据写入Excel
- 使用IO流创建文件并写入数据
- java实现从数据库读取数据写入excel,写入多个sheet,6万数据耗时100秒附近
- 使用poi导入excel文件数据到数据库
- 使用Greendao进行批量添加数据(Android Studio读取assets下的数据库文件)
- 解决:Android使用自带sqlite开发时,apk中创建的数据库外部的进程是没有权限去读/写的,而且无法如何读取指定目录下的db文件
- 使用java语言将数组中的数据写入txt文件,然后读取
- 使用JAVA读取EXCEL文件里面的数据
- python 在excel文件中写入date日期数据,以及读取excel日期数据,如何在python中正确显示date日期。
- NPOI 创建Excel,数据读取与写入
- vc2008: 控制台程序将数据写入MySql(数据库信息从配置文件读取)