使用POI產生Excel檔案

來源:互聯網
上載者:User

在開發中經常需要用到對Excel檔案的操作,現在根據網上的資料整理如下:


import java.io.FileOutputStream;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFComment;
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;

public class PoiCreateExcelTest ...{
    public static void main(String[] args) ...{
        /** *//**
          * @see <a href="http://poi.apache.org/hssf/quick-guide.html#NewWorkbook">For more</a>
         */        
        // 建立新的Excel 活頁簿
         HSSFWorkbook workbook = new HSSFWorkbook();
        
        // 在Excel活頁簿中建一工作表,其名為預設值, 也可以指定Sheet名稱
         HSSFSheet sheet = workbook.createSheet();
        //HSSFSheet sheet = workbook.createSheet("SheetName");
        
        // 用于格式化儲存格的資料
         HSSFDataFormat format = workbook.createDataFormat();
        
        // 建立新行(row),並將儲存格(cell)放入其中. 行號從0開始計算.
         HSSFRow row = sheet.createRow((short) 1);

        // 設定字型
         HSSFFont font = workbook.createFont();
         font.setFontHeightInPoints((short) 20); //字型高度
         font.setColor(HSSFFont.COLOR_RED); //字型顏色
         font.setFontName("黑體"); //字型
         font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); //寬度
         font.setItalic(true); //是否使用斜體
//         font.setStrikeout(true); //是否使用劃線

        // 設定儲存格樣式

         HSSFCellStyle cellStyle = workbook.createCellStyle();
         cellStyle.setFont(font);
         cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); //水平布局:置中

// 設定儲存格的文本方式為可多行編寫方式
cellStyle.setWrapText(true);

// 設定儲存格的填充方式,以及前景顏色和背景顏色
// 三點注意:
// 1.如果需要前景顏色或背景顏色,一定要指定填充方式,兩者順序無所謂;
// 2.如果同時存在前景顏色和背景顏色,前景顏色的設定要寫在前面;
// 3.前景顏色不是字型顏色。
cellStyle.setFillPattern(HSSFCellStyle.DIAMONDS);
cellStyle.setFillForegroundColor(HSSFColor.RED.index);
cellStyle.setFillBackgroundColor(HSSFColor.LIGHT_YELLOW.index);

// 設定儲存格底部的邊框及其樣式和顏色
// 這裡僅設定了底邊邊框,左邊框、右邊框和頂邊框同理可設
cellStyle.setBorderBottom(HSSFCellStyle.BORDER_SLANTED_DASH_DOT);
cellStyle.setBottomBorderColor(HSSFColor.DARK_RED.index);

        
        // 添加儲存格注釋
        // 建立HSSFPatriarch對象,HSSFPatriarch是所有注釋的容器.
         HSSFPatriarch patr = sheet.createDrawingPatriarch();
        // 定義注釋的大小和位置,詳見文檔
         HSSFComment comment = patr.createComment(new HSSFClientAnchor(0, 0, 0, 0, (short)4, 2, (short) 6, 5));
        // 設定注釋內容
         comment.setString(new HSSFRichTextString("可以在POI中添加註釋!"));
        // 設定注釋作者. 當滑鼠移動到儲存格上是可以在狀態列中看到該內容.
         comment.setAuthor("Xuys.");
        
        // 建立儲存格
         HSSFCell cell = row.createCell((short) 1);
         HSSFRichTextString hssfString = new HSSFRichTextString("Hello World!");
         cell.setCellValue(hssfString);//設定儲存格內容
         cell.setCellStyle(cellStyle);//設定儲存格樣式
         cell.setCellType(HSSFCell.CELL_TYPE_STRING);//指定儲存格格式:數值、公式或字串
         cell.setCellComment(comment);//添加註釋

        //格式化資料
         row = sheet.createRow((short) 2);
         cell = row.createCell((short) 2);
         cell.setCellValue(11111.25);
         cellStyle = workbook.createCellStyle();
         cellStyle.setDataFormat(format.getFormat("0.0"));
         cell.setCellStyle(cellStyle);

         row = sheet.createRow((short) 3);
         cell = row.createCell((short) 3);
         cell.setCellValue(9736279.073);
         cellStyle = workbook.createCellStyle();
         cellStyle.setDataFormat(format.getFormat("#,##0.0000"));
         cell.setCellStyle(cellStyle);
        
        
         sheet.autoSizeColumn((short)0); //調整第一列寬度
         sheet.autoSizeColumn((short)1); //調整第二列寬度
         sheet.autoSizeColumn((short)2); //調整第三列寬度
         sheet.autoSizeColumn((short)3); //調整第四列寬度

        try ...{
             FileOutputStream fileOut = new FileOutputStream("C:/3.xls");
             workbook.write(fileOut);
             fileOut.close();
         } catch (Exception e) ...{
             System.out.println(e.toString());
         }
     }

}

最後自動調整列寬的代碼是在找了好久以後不經意間找著的,很驚喜!
如果編譯器提示沒有autoSizeColumn這個方法,那可能是你的poi版本太低的緣故,我用的是poi3.0版本

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.