How to read Excel sheet in Java?

An example of reading and parsing an Excel file.


We have a class (HomeObject) and this class has two attributes ('doorNo' and 'ownerName').

public class HomeObject {
private int doorNo;
private String ownerName;

public int getDoorNo() {
return doorNo;
}
public void setDoorNo(int doorNo) {
this.doorNo = doorNo;
}
public String getOwnerName() {
return ownerName;
}
public void setOwnerName(String ownerName) {
this.ownerName = ownerName;
}
}
Now we want to read data from Excel sheet columns and add into a list in our ExcelParser class.
For this purpose, we use The Apache POI project library.

First of all, we add this code into import part of your ExcelParser class.

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;
We need a function that controls data compability in sheet columns.

private String getCellValue(HSSFCell cell) {
if (cell == null) return null;
String result = null;
int cellType = cell.getCellType();
switch (cellType) {
case HSSFCell.CELL_TYPE_BLANK:
result = "";
break;
case HSSFCell.CELL_TYPE_BOOLEAN:
result = cell.getBooleanCellValue() ? "true" : "false";
break;
case HSSFCell.CELL_TYPE_ERROR:
result = "ERROR: " + cell.getErrorCellValue();
break;
case HSSFCell.CELL_TYPE_FORMULA:
result = cell.getCellFormula();
break;
case HSSFCell.CELL_TYPE_NUMERIC:
result = String.valueOf((long) cell.getNumericCellValue());
break;
case HSSFCell.CELL_TYPE_STRING:
result = cell.toString();
break;
default:
break;
}
return result;
}
and we add that code into main function in ExcelParser class.
try {
HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(file));
// we assume we have data only in the first sheet.
HSSFSheet sheet = workbook.getSheetAt(0);
List homeObjects = new LinkedList();
HomeObject homeObject;
for (Iterator rows = sheet.rowIterator(); rows.hasNext();) {
HSSFRow row = (HSSFRow) rows.next();
// we know that the first line is for column names. we won't use it
if (row.getRowNum() == 0) continue;
homeObject = new HomeObject();
homeObject.setDoorNo(getCellValue(row.getCell((short) 0)));
homeObject.setOwnerName(getCellValue(row.getCell((short) 1)));
homeObjects.add(homeObject);
}
} catch (IOException e) {
// todo : error handling
}
Now, we have a list contains column data as HomeObject objects to use.

What is agile?

I decided to write about Agile development and Agile practices days ago. But I coudn't have time to write. At last I've decided to write all as a series of short blog-posts.

In this post, I'll try to explain "what is agile?".


Agile term used to mean for thinking and reacting very quickly. In software industry, it has more meaning. Agile refers to a group of software development practices which let the software project adopt to change quickly. But Agile is not a method by itself. It's an umbrealla term for some iterative and incremental methodologies such as Scrum, XP (Extreme Programming), Crystal Clear, and DSDM.

In 2001, 17 agile evangelists met to discuss the need for lighter alternatives to the traditional methodologies and declared Agile manifesto. This manifesto defined four values and twelve principles for agile software development. The values are:
  • Individuals and interactions over processes and tools
  • Working software over comprehensive documentation
  • Customer collaboration over contract negotiation
  • Responding to change over following a plan
and 12 principles:
  1. Customer satisfaction through early and continuous delivery of valuable software
  2. Welcome changing requirements, even late.
  3. Deliver working software frequently (iterations)
  4. Daily communication between business people and development team
  5. Projects around motivated individuals
  6. Face-to-face conversation to convey information within development team.
  7. The primary measure of progress is working software
  8. Sustainable development pace
  9. Technical excellence and good design
  10. Simplicity
  11. Self-organizing teams
  12. Reflection on how to become more effective at regular intervals
These priorities and principles are still the basis of agile. But I think Agile is more than these things. I mean Agile methods. I'll write about all step by step. :)

Hello World


public class HelloWorld {

public static void main(String[] args) {
System.out.println("Hello, World");
}

}