溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

java生成excel報(bào)表文件示例

發(fā)布時(shí)間:2020-09-28 05:47:59 來源:腳本之家 閱讀:164 作者:一念花開滿天下 欄目:編程語言

此次簡(jiǎn)單的操作將數(shù)據(jù)從數(shù)據(jù)庫導(dǎo)出生成excel報(bào)表以及將excel數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫

首先建立數(shù)據(jù)庫的連接池:

package jdbc;

import java.io.FileInputStream;
import java.sql.Connection;
import java.util.Properties;

import org.apache.commons.dbcp.BasicDataSource;

public class BaseDAO {
  private static BasicDataSource ds;
  static{                                         
    try {                                         
      //1.讀取配置文件conf.properties,采用java.util.Properties來讀取           
      Properties p=new Properties();                           
      //2.通過文件流讀取并解析配置文件內(nèi)容,本地?cái)?shù)據(jù)庫用的mysql,所以把配置文件mysql的配置放開,其他數(shù)據(jù)庫配置注釋                        
      p.load(new FileInputStream("src/jdbc.properties"));                  
      String driverName=p.getProperty("jdbc.driverClassName");//獲取驅(qū)動(dòng)名稱            
      String url=p.getProperty("jdbc.url");//獲取數(shù)據(jù)庫的url                
      String user=p.getProperty("jdbc.username");//用戶名                     
      String password=p.getProperty("jdbc.password");//密碼                  
      int maxActive=Integer.parseInt(p.getProperty("jdbc.maxActive"));//獲取最大連接數(shù)     
      int maxWait=Integer.parseInt(p.getProperty("jdbc.maxWait"));//獲取最大等待時(shí)間      
      //3.創(chuàng)建一個(gè)連接池                                 
      ds=new BasicDataSource();                              
      ds.setDriverClassName(driverName);//設(shè)置驅(qū)動(dòng)名稱                  
      ds.setUrl(url);//設(shè)置數(shù)據(jù)庫地址                           
      ds.setUsername(user);//設(shè)置用戶名                          
      ds.setPassword(password);//設(shè)置密碼                         
      ds.setMaxActive(maxActive);//設(shè)置最大連接數(shù)                     
      ds.setMaxWait(maxWait);//設(shè)置最大等待時(shí)間                                                                
    } catch (Exception e) {                                
      e.printStackTrace();                                
    }                                           
  }
  
  public static Connection getConnection() throws Exception {
    try {
      return ds.getConnection();
    } catch (Exception e) {
      System.out.println("連接數(shù)據(jù)庫異常");
      throw e;
    }
  }
  
  public static void close(Connection conn){                       
    if(conn!=null){                                    
      try {                                        
        conn.close();                                   
      } catch (Exception e) {                               
        e.printStackTrace();                               
      }                                          
    }                                           
  } 

}

生成與數(shù)據(jù)庫相對(duì)應(yīng)的java實(shí)體類:

package entity;

public class Test {
  private String a;
  private String b;
  private String c;  
  private String d;
  private String e;
  private String f;
  private String g;
  private String h;
  private String i;
  private String j;
  public String getA() {
    return a;
  }
  public void setA(String a) {
    this.a = a;
  }
  public String getB() {
    return b;
  }
  public void setB(String b) {
    this.b = b;
  }
  public String getC() {
    return c;
  }
  public void setC(String c) {
    this.c = c;
  }
  public String getD() {
    return d;
  }
  public void setD(String d) {
    this.d = d;
  }
  public String getE() {
    return e;
  }
  public void setE(String e) {
    this.e = e;
  }
  public String getF() {
    return f;
  }
  public void setF(String f) {
    this.f = f;
  }
  public String getG() {
    return g;
  }
  public void setG(String g) {
    this.g = g;
  }
  public String getH() {
    return h;
  }
  public void setH(String h) {
    this.h = h;
  }
  public String getI() {
    return i;
  }
  public void setI(String i) {
    this.i = i;
  }
  public String getJ() {
    return j;
  }
  public void setJ(String j) {
    this.j = j;
  }
  

}

將excel表格數(shù)據(jù)插入數(shù)據(jù)庫,先讀取excel表格數(shù)據(jù)

package readExcel;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;


public class ReadExcel {

  /**
   * @param args
   * @throws IOException 
   */
  
  public List<List<String>> readExcel(File file) throws IOException{
    List<List<String>> list=new ArrayList<List<String>>();
    if(!file.exists()){
      System.out.println("文件不存在");
    }else{
      InputStream fis=new FileInputStream(file);  
      list=parseExcel(file,fis);
    }
    return list;    
  }
  
  public List<List<String>> parseExcel(File file,InputStream fis) throws IOException{
    Workbook workbook=null;
    List<List<String>> list=new ArrayList<List<String>>();
    if(file.toString().endsWith("xls")){
      workbook=new HSSFWorkbook(fis);
    }else if(file.toString().endsWith("xlsx")){
      workbook=new XSSFWorkbook(fis);
    }else{
      System.out.println("文件不是excel文檔類型 ,此處無法讀取");
    }
    for(int i=0;i<workbook.getNumberOfSheets();i++){
      Sheet sheet=workbook.getSheetAt(i); 
      if(sheet!=null){        
        int lastRow=sheet.getLastRowNum();
        //獲取表格中的每一行
        for(int j=0;j<=lastRow;j++){
          Row row=sheet.getRow(j);
          short firstCellNum=row.getFirstCellNum();
          short lastCellNum=row.getLastCellNum();  
          List<String> rowsList=new ArrayList<String>();
          if(firstCellNum!=lastCellNum){            
            //獲取每一行中的每一列
            for(int k=firstCellNum;k<lastCellNum;k++){
              Cell cell=row.getCell(k);
              if(cell==null){
                rowsList.add("");
              }else{
                rowsList.add(chanegType(cell));
              }
            }
          }else{
            System.out.println("該表格只有一列");
          }
          list.add(rowsList);
        }
        
      }
    }
    return list;  
  }
  
  public String chanegType(Cell cell){
    String result = new String(); 
    switch (cell.getCellType()) { //獲取單元格的類型
    case HSSFCell.CELL_TYPE_NUMERIC:// 數(shù)字類型 
      if(cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){ //如果是數(shù)值類型
        short format = cell.getCellStyle().getDataFormat(); //獲取這個(gè)單元的類型對(duì)應(yīng)的數(shù)值
        SimpleDateFormat sdf = null; 
        if(format == 14 || format == 31 || format == 57 || format == 58){ //如果數(shù)值為14,31,57,58其中的一種 
          //對(duì)應(yīng)的日期格式為 2016-03-01這種形式,
          sdf = new SimpleDateFormat("yyyy-MM-dd"); 
          double value = cell.getNumericCellValue(); 
          Date date = org.apache.poi.ss.usermodel.DateUtil.getJavaDate(value); 
          result = sdf.format(date);//得到y(tǒng)yyy-MM-dd這種格式日期
        }else if (format == 20 || format == 32) { 
          //時(shí)間 
          sdf = new SimpleDateFormat("HH:mm"); 
          double value = cell.getNumericCellValue(); 
          Date date = org.apache.poi.ss.usermodel.DateUtil.getJavaDate(value); 
          result = sdf.format(date);//得到HH:mm
        } else {
          double value = cell.getNumericCellValue(); 
          CellStyle style = cell.getCellStyle(); 
          DecimalFormat dataformat = new DecimalFormat(); 
          String temp = style.getDataFormatString(); 
          // 單元格設(shè)置成常規(guī) 
          if (temp.equals("General")) { 
            dataformat.applyPattern("#"); 
          } 
          result = dataformat.format(value); //得到單元格數(shù)值
        }
      } 
      break; 
    case HSSFCell.CELL_TYPE_STRING:// String類型 
      result = cell.getRichStringCellValue().toString(); 
      break; 
    case HSSFCell.CELL_TYPE_BLANK: 
      result = ""; 
    default: 
      result = ""; 
      break; 
    } 
    return result;    
  }  
}

將讀取到的excel表格數(shù)據(jù)插入到數(shù)據(jù)庫中去

package importdata;

import java.io.File;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.util.ArrayList;
import java.util.List;

import entity.Test;
import readExcel.ReadExcel;
import jdbc.BaseDAO;
public class inportData {
  
  
  
  public static void main(String[] args) throws Exception {
    // TODO Auto-generated method stub
    List<List<String>> list = new ArrayList<List<String>>();
    ReadExcel readExcel=new ReadExcel();
    File file=new File("d:/test.xlsx");
    list=readExcel.readExcel(file);
    
    Test test=new Test();
    Connection conn=BaseDAO.getConnection();
    PreparedStatement ps=null;
    int i=1;
    for(List<String> rowlist:list){
      if(rowlist!=null){
        test.setA(rowlist.get(0).toString());
        test.setB(rowlist.get(1).toString());
        test.setC(rowlist.get(2).toString());
        test.setD(rowlist.get(3).toString());      
        test.setE(rowlist.get(4).toString());
        test.setF(rowlist.get(5).toString());
        test.setG(rowlist.get(6).toString());
        test.setH(rowlist.get(7).toString());
        test.setI(rowlist.get(8).toString());
        test.setJ(rowlist.get(9).toString());
        String sql="insert into TEST(A,B,C,D,E,F,G,H,I,J) values(?,?,?,?,?,?,?,?,?,?)";
        ps=conn.prepareStatement(sql);
        ps.setString(1,test.getA());
        ps.setString(2,test.getB());
        ps.setString(3,test.getC());
        ps.setString(4,test.getD());
        ps.setString(5,test.getE());
        ps.setString(6,test.getF());
        ps.setString(7,test.getG());
        ps.setString(8,test.getH());
        ps.setString(9,test.getI());
        ps.setString(10,test.getJ());
        int n=ps.executeUpdate();
        if(n!=1){
          System.out.println("數(shù)據(jù)插入數(shù)據(jù)庫失敗");
        }
        System.out.println("第"+i+"條數(shù)據(jù)插入成功");
        System.out.println();
        i++;
      }
    }
    
    
  }

}

將數(shù)據(jù)庫中的數(shù)據(jù)查詢出來并以excel表格的形式生成報(bào)表

package export;

import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import entity.Test;

import jdbc.BaseDAO;

public class Export {
  
  
  public static void createExcel(List<Test> list){
    FileOutputStream fos=null;
    Workbook workbook=new XSSFWorkbook();  
    Sheet sheet=workbook.createSheet("測(cè)試文件");
    String[] title={"第一列","第二列","第三列","第四列","第五列","第六列","第七列","第八列","第九列","第十列"};
    Row row=sheet.createRow((short)0);
    int i=0;
    for(String s:title){
      Cell cell=row.createCell(i);
      cell.setCellValue(s);
      i++;
    }
    int j=1;
    for(Test t:list){
      //創(chuàng)建第二行
      Row rowData=sheet.createRow((short)j);
      //第一列數(shù)據(jù)
      Cell cell0=rowData.createCell((short)0);
      cell0.setCellValue(t.getA());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第二列數(shù)據(jù)
      Cell cell1=rowData.createCell((short)1);
      cell1.setCellValue(t.getB());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第三列數(shù)據(jù)
      Cell cell2=rowData.createCell((short)2);
      cell2.setCellValue(t.getC());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第四列數(shù)據(jù)
      Cell cell3=rowData.createCell((short)3);
      cell3.setCellValue(t.getD());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第五列數(shù)據(jù)
      Cell cell4=rowData.createCell((short)4);
      cell4.setCellValue(t.getE());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第六列數(shù)據(jù)
      Cell cell5=rowData.createCell((short)5);
      cell5.setCellValue(t.getF());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第七列數(shù)據(jù)
      Cell cell6=rowData.createCell((short)6);
      cell6.setCellValue(t.getG());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第八列數(shù)據(jù)
      Cell cell7=rowData.createCell((short)7);
      cell7.setCellValue(t.getH());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第九列數(shù)據(jù)
      Cell cell8=rowData.createCell((short)8);
      cell8.setCellValue(t.getI());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      //第十列數(shù)據(jù)
      Cell cell9=rowData.createCell((short)9);
      cell9.setCellValue(t.getJ());
      //設(shè)置單元格的寬度
      sheet.setColumnWidth((short)0, (short)10000);
      j++;
    }
    try {
      //導(dǎo)出數(shù)據(jù)庫文件保存路徑
      fos=new FileOutputStream("D:/export.xlsx");
      /*if(fos.toString().endsWith("xlsx")){
        workbook=new XSSFWorkbook();
      }else if(fos.toString().endsWith("xls")){
        workbook=new HSSFWorkbook();
      }*/
      //將工作簿寫入文件
      workbook.write(fos);  
      System.out.println("導(dǎo)出文件成功");
    } catch (IOException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      System.out.println("導(dǎo)出文件失敗");
    }
  }
  public static void main(String[] args) throws Exception {
    //連接數(shù)據(jù)庫
    Connection conn=BaseDAO.getConnection();
    PreparedStatement ps=null;    
    String sql="select * from TEST";
    //執(zhí)行sql語句
    ps=conn.prepareStatement(sql);
    //查詢數(shù)據(jù)庫之后得到的結(jié)果
    ResultSet rs=ps.executeQuery();
    List<Test> list=new ArrayList<Test>();
    //遍歷查詢結(jié)果
    while(rs.next()){
      Test test=new Test();
      test.setA(rs.getString("A"));
      test.setB(rs.getString("B"));
      test.setC(rs.getString("C"));
      test.setD(rs.getString("D"));
      test.setE(rs.getString("E"));
      test.setF(rs.getString("F"));
      test.setG(rs.getString("G"));
      test.setH(rs.getString("H"));
      test.setI(rs.getString("I"));
      test.setJ(rs.getString("J"));
      list.add(test);      
    }
    createExcel(list);
  }
  
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI