SpringBoot加Poi仿照EasyPoi實現Excel導出

POI提供API給Java程序對Microsoft Office格式檔案讀和寫的功能,詳細功能能夠直接查閱API,由於使用EasyPoi過程當中老是缺乏依賴,沒有搞明白究竟是什麼坑,索性本身寫一個簡單工具類,來實現不管傳入任何對象集合,都可以實現導出Excel的功能,沒有看EasyPoi的源碼, 只是在功能上模仿一下。javascript

首先導入基本依賴,除了SpringBoot基本依賴依賴,導入Poi的依賴java

<!-- https://mvnrepository.com/artifact/org.apache.poi/poi -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.17</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.17</version>
        </dependency>

編寫自定義註解apache

@Retention(RetentionPolicy.RUNTIME)
public @interface Excel {
    
//Excel列名稱 String name()
default "";
//Excel列數
int orderNum() default 0; }

編寫javaBean,全部須要導出的屬性都使用Excel註解api

public class Person{


   private String id;


   @Excel(name = "用戶姓名")
    private String userName;

    @Excel(name = "電話",orderNum = 1)
    private String phone;

   @Excel(name = "郵箱",orderNum = 2)
    private String email;
 
   @Excel(name = "地址",orderNum = 3)
    private  String address;

     
   public  void setId(String id){

    this.id=id;
    } 


    public String getId(){
       return id;
    }
   

     
   public  void setUserName(String userName){

    this.userName=userName;
    } 


    public String getUserName(){
       return userName;
    }
    
    public  void setphone(String phone){

      this.phone=phone;
    } 


    public String getphone(){
       return phone;
    }

   public  void setEmail(String email){

    this.email=email;
    } 


    public String getEmail(){
       return email;
    }

    public  void setAddress(String address){

    this.address=address;
    } 


    public String getAddress(){
       return address;
    }

}

 

編寫工具類瀏覽器

public class PoiUtils {


    /**
     *
     * 功能描述:
     * 須要導出的屬性要加Excel註解,實現Excel導出功能
     * @param: [list, fileName, sheetName, response, clazz]
     * @return: void
     * @auther: wang
     * @date: 2019/1/18 15:31
     */
    public Static <T> void export(Collection<T> collection, String fileName, String sheetName, HttpServletResponse response, Class<?> clazz) throws IOException, IntrospectionException, InvocationTargetException, IllegalAccessException {

        HSSFWorkbook workbook = new HSSFWorkbook();
        //建立一個Excel表單,參數爲sheet的名字
        HSSFSheet sheet = workbook.createSheet(sheetName);
        //建立表頭
        setTitle(workbook, sheet, clazz);
        //新增數據行,而且設置單元格數據
        int rowNum = 1;
        for (T t : collection) {
            HSSFRow row = sheet.createRow(rowNum);
            Field[] fields = clazz.getDeclaredFields();
            for (Field field : fields) {
                if (field.isAnnotationPresent(Excel.class)) {
                    PropertyDescriptor pd = new PropertyDescriptor(field.getName(),
                            clazz);
                    Method getMethod = pd.getReadMethod();//得到get方法
                    Excel excel = field.getAnnotation(Excel.class);
                    row.createCell(excel.orderNum()).setCellValue(String.valueOf(getMethod.invoke(t)));

                }

            }
            rowNum++;
        }
        //清空response
        response.reset();
        // 告訴瀏覽器用什麼軟件能夠打開此文件
        response.setHeader("content-Type", "application/vnd.ms-excel");
        // 下載文件的默認名稱
        response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName + ".xls", "utf-8"));
        OutputStream os;
        //能夠將生成Excel默認下載到某個目錄下
        //os = new BufferedOutputStream(new FileOutputStream("D:\\bmj\\target\\bmj128-0.0.1\\" + fileName));
//也能夠經過response獲得輸出流,寫到輸出流中,在頁面中進行下載 os = new BufferedOutputStream(response.getOutputStream()); //將excel寫入到輸出流中 workbook.write(os); os.flush(); os.close(); } /*** * 設置表頭 * @param workbook * @param sheet */ private static void setTitle(HSSFWorkbook workbook, HSSFSheet sheet, Class clazz) { HSSFRow row = sheet.createRow(0); Field[] fields = clazz.getDeclaredFields(); //設置爲居中加粗 HSSFCellStyle style = workbook.createCellStyle(); HSSFFont font = workbook.createFont(); //設置字體 font.setFontName("宋體"); //設置粗體 font.setBold(true); //設置字號 font.setFontHeightInPoints((short) 14); //設置顏色 font.setColor(IndexedColors.BLACK.index); style.setFont(font); HSSFCell cell; for (Field field : fields) { if (field.isAnnotationPresent(Excel.class)) { Excel excel = field.getAnnotation(Excel.class); cell = row.createCell(excel.orderNum()); cell.setCellValue(excel.name()); cell.setCellStyle(style); sheet.setColumnWidth(excel.orderNum(), 30*256); } } } }

頁面調用,頁面採用的是EasyUI框架app

      <div style="padding:5px;background:#fafafa;width:100%;">
            <a href="javascript:void(0)" class="easyui-linkbutton" plain="true" iconCls="icon-undo"  onclick="downLoadExcel()">導出日誌</a>
      </div>

能夠按照頁面給增長篩選條件,根據篩選條件下載框架

   function downLoadExcel(){

        var url=base+'/api/xx?xx='+$("#xx").val()+'&xx='+$("#xx").val()+'&xx='+$("#xx").val();
        window.location.href = url;

    }

 

編寫Controller工具

@RestController
@RequestMapping(value = "/api/xx")
public class PersonController {

    private static final Logger LOG = LoggerFactory.getLogger(PersonController .class);
    @Resource(name = "personService")
    private PersonService personService;



    @RequestMapping("/export")
    public void export(PersonQuery personQuery, HttpServletResponse response) {

        List<Person> personList = personService.selectAll(personQuery);

        try {
            PoiUtils.export(auditLogList, "審計日誌", "審計日誌", response,AuditLog.class);
        } catch (IOException | IntrospectionException | InvocationTargetException | IllegalAccessException e) {
           LOG.error("審計日誌錯誤{}",e);
        }

    }


}

 

頁面以下字體

點擊導出日誌,顯示以下ui

 

 

 目前僅僅是針對單個sheet的操做,也沒有像合併單元格這種複雜操做,須要繼續完善。

相關文章
相關標籤/搜索