In this tutorial, I’d love to share with you guys some examples of writing data to Excel files using the Apache POI library. If today is the first day you get to know Apache POI and you haven’t written any code snippet to read/write Excel files yet, I recommend you to read the sections 1 and 2 in the tutorial How to Read Excel Files in Java using Apache POI to understand the fundamentals of Apache POI.Or if you are a kind of person who likes getting your hands-dirty first, let jump directly into the following examples. 
This program creates an Excel 2007 document which looks like the following screenshot (File: JavaBooks.xlsx): 
You can see the complete program (FormattedExcelWriterExample.java) which can be found in the source code attached to this article. 
You can see the complete program (FlexibleExcelWriterExample.java) which can be found in the source code attached to this article.That's how to read Excel files in Java programmatically. To learn more in-depth about Java programming, this Java software developers course would be good choice.
      1. Apache POI API Basics for Writing Excel Files
The fundamental interfaces include Workbook, Sheet, Row and Cell. For basic formatting, use the CellStyle and Font interfaces. Concrete implementing classes include:- Excel 2003: HSSFWorkbook, HSSFSheet, HSSFRow, HSSFCell, etc.
- Excel 2007: XSSFWorkbook, XSSFSheet, XSSFRow, XSSFCell, etc.
- Create a Workbook.
- Create a Sheet.
- Repeat the following steps until all data is processed:- Create a Row.
- Create Cellsin a Row. Apply formatting using CellStyle.
 
- Write to an OutputStream.
- Close the output stream.
2. A Simple Example to create an Excel file in Java
The following code snippet is a very simple program that demonstrates writing a list of books to an Excel file in the simplest and dirty form:| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | packagenet.codejava.excel;importjava.io.FileOutputStream;importjava.io.IOException;importorg.apache.poi.ss.usermodel.Cell;importorg.apache.poi.ss.usermodel.Row;importorg.apache.poi.xssf.usermodel.XSSFSheet;importorg.apache.poi.xssf.usermodel.XSSFWorkbook;/** * A very simple program that writes some data to an Excel file * using the Apache POI library. * @author www.codejava.net * */publicclassSimpleExcelWriterExample {    publicstaticvoidmain(String[] args) throwsIOException {        XSSFWorkbook workbook = newXSSFWorkbook();        XSSFSheet sheet = workbook.createSheet("Java Books");                Object[][] bookData = {                {"Head First Java", "Kathy Serria", 79},                {"Effective Java", "Joshua Bloch", 36},                {"Clean Code", "Robert martin", 42},                {"Thinking in Java", "Bruce Eckel", 35},        };        introwCount = 0;                for(Object[] aBook : bookData) {            Row row = sheet.createRow(++rowCount);                        intcolumnCount = 0;                        for(Object field : aBook) {                Cell cell = row.createCell(++columnCount);                if(field instanceofString) {                    cell.setCellValue((String) field);                } elseif(field instanceofInteger) {                    cell.setCellValue((Integer) field);                }            }                    }                        try(FileOutputStream outputStream = newFileOutputStream("JavaBooks.xlsx")) {            workbook.write(outputStream);        }    }} | 
3. A More Object-Oriented Example to create an Excel file in Java
The following code snippets demonstrate a nicer program that focuses on OOP approach. That makes the program more flexible and easy to extend or upgrade in the future.- Create the model class (Book.java):123456789101112131415161718packagenet.codejava.excel;publicclassBook {privateString title;privateString author;privatefloatprice;publicBook() {}publicBook(String title, String author,doubleprice) {this.title = title;this.author = author;this.price = price;}// getters and setters}
- The method that writes a list of books to an Excel file (in 2003 format):123456789101112131415publicvoidwriteExcel(List<Book> listBook, String excelFilePath)throwsIOException {Workbook workbook =newHSSFWorkbook();Sheet sheet = workbook.createSheet();introwCount =0;for(Book aBook : listBook) {Row row = sheet.createRow(++rowCount);writeBook(aBook, row);}try(FileOutputStream outputStream =newFileOutputStream(excelFilePath)) {workbook.write(outputStream);}}
- The method that writes information of a book to cells:12345678910privatevoidwriteBook(Book aBook, Row row) {Cell cell = row.createCell(1);cell.setCellValue(aBook.getTitle());cell = row.createCell(2);cell.setCellValue(aBook.getAuthor());cell = row.createCell(3);cell.setCellValue(aBook.getPrice());}
- The following method creates some dummy data (a list of books):12345678910privateList<Book> getListBook() {Book book1 =newBook("Head First Java","Kathy Serria",79);Book book2 =newBook("Effective Java","Joshua Bloch",36);Book book3 =newBook("Clean Code","Robert Martin",42);Book book4 =newBook("Thinking in Java","Bruce Eckel",35);List<Book> listBook = Arrays.asList(book1, book2, book3, book4);returnlistBook;}
- And the following code snippet is for testing:123456NiceExcelWriterExample excelWriter =newNiceExcelWriterExample();List<Book> listBook = excelWriter.getListBook();String excelFilePath ="NiceJavaBooks.xls";excelWriter.writeExcel(listBook, excelFilePath);
4. Formatting Cells of the Excel file
Of course you may need to format the Excel file to make it looks nicely and professionally. Formatting is diversity and quite complex so in this introductory tutorial, I just show you how to format the basics like setting font style. Here are the steps:- Create a CellStyle object what holds formatting information:1CellStyle cellStyle = sheet.getWorkbook().createCellStyle();
- Invoke the appropriate setters to apply the formatting you want. For example:123cellStyle.setAlignment(CellStyle.ALIGN_CENTER);cellStyle.setFont(font);cellStyle.setWrapText(true);
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | privatevoidcreateHeaderRow(Sheet sheet) {    CellStyle cellStyle = sheet.getWorkbook().createCellStyle();    Font font = sheet.getWorkbook().createFont();    font.setBold(true);    font.setFontHeightInPoints((short) 16);    cellStyle.setFont(font);    Row row = sheet.createRow(0);    Cell cellTitle = row.createCell(1);    cellTitle.setCellStyle(cellStyle);    cellTitle.setCellValue("Title");    Cell cellAuthor = row.createCell(2);    cellAuthor.setCellStyle(cellStyle);    cellAuthor.setCellValue("Author");    Cell cellPrice = row.createCell(3);    cellPrice.setCellStyle(cellStyle);    cellPrice.setCellValue("Price");} | 
5. Writing both Excel 2003 and Excel 2007 formats in Java
For better flexibility (supporting both common Excel formats), I recommend writing a factory method that either returns a HSSFWorkbook or XSSFWorkbook, depending on the extension of the file (.xls or .xlsx). Here’s the method:| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | privateWorkbook getWorkbook(String excelFilePath)        throwsIOException {    Workbook workbook = null;    if(excelFilePath.endsWith("xlsx")) {        workbook = newXSSFWorkbook();    } elseif(excelFilePath.endsWith("xls")) {        workbook = newHSSFWorkbook();    } else{        thrownewIllegalArgumentException("The specified file is not Excel file");    }    returnworkbook;} |