Java导出Excel文件(jxl.jar版)(详细解读)
import jxl.*;
import jxl.write.*;
public class ExportData
{
public void exportProduct()
{
try
{
//类login(javabean)的managed-bean-scope属性设置成session,这样可以调用login中当前用户的id。这个非常有用。
login me = (login) FacesContext.getCurrentInstance().getExternalContext().getSessionMap().get("login");
String userId = String.valueOf(me.getID_());
//设置导出文件在服务器上的存储路径,getBasedir()和getSeparator()根据服务器OS来判断当前路径和连接符,Windows 和Linux不一样。
String storedir = getBasedir() + userId + getSeparator();
//System.out.println("storedir:" + storedir);
//System.out.println("main.isDirExists(storedir):" + main.isDirExists(storedir));
//如果storedir文件不存在,就创建它
if(main.isDirExists(storedir))
{
storedir = storedir + "exportExcel.xls";
File file = new File(storedir);
if(file.exists())
file.delete();
//创建一个excel文件
jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(new File(storedir));
//创建一个工作簿
jxl.write.WritableSheet ws = wwb.createSheet("data", 0);
//定义excel的文本单元格
jxl.write.Label label;
//定义excel的数值单元格
jxl.write.Number number;
//格式化数值
jxl.write.NumberFormat nf = new jxl.write.NumberFormat("#.####");
jxl.write.WritableCellFormat wcNf = new jxl.write.WritableCellFormat(nf);
//从0开始,设置列标题
label = new jxl.write.Label(0,0, "物品编码");
ws.addCell(label);
label = new jxl.write.Label(1,0, "物品描述");
ws.addCell(label);
label = new jxl.write.Label(2,0, "库存数量");
ws.addCell(label);
label = new jxl.write.Label(3,0, "入库日期");
ws.addCell(label);
label = new jxl.write.Label(4,0, "在库天数");
ws.addCell(label);
label = new jxl.write.Label(5,0, "在库月份");
ws.addCell(label);
label = new jxl.write.Label(6,0, "入库数量");
ws.addCell(label);
label = new jxl.write.Label(7,0, "成本");
ws.addCell(label);
label = new jxl.write.Label(8,0, "总成本");
ws.addCell(label);
main.oracleSession.clear();
//循环提取表中的数据
Query query = main.oracleSession.getNamedQuery("masQuery.selectProductStock");
List list = query.list();
String pItemCode,pItemDesc,pQuantity,pTranDate,pDays,pMonths,pTranQuantity,pCost,pTotalCost;
for(int i=0;i