Posted on 2012-03-05 16:37
viery 阅读(824)
评论(0) 编辑 收藏 所属分类:
JavaEE
1在apache
http://poi.apache.org/download.html上下载poi开源控件包。目前最稳定的版本:
The latest stable release is Apache POI 3.7 2将poi.jar引入项目
3更改业务逻辑,将业务逻辑返回的查询到的对象集合存入session
request.getSession().setAttribute("pclist", list);
4建立ToExcelAction
data:image/s3,"s3://crabby-images/f4fe2/f4fe2905e6a68eecdb5a9c900ae477a6bd055e40" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
package com.vle.oa.action;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import java.util.List;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.CellRangeAddress;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CreationHelper;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.actions.DispatchAction;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import com.vle.oa.domain.Pc;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
public class ToExcelAction extends DispatchAction
{
@Override
protected ActionForward unspecified(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
throws Exception
{
Workbook wb = new HSSFWorkbook();
//Workbook wb = new XSSFWorkbook();
CreationHelper createHelper = wb.getCreationHelper();
//设置样式
HSSFCellStyle titleSytle=(HSSFCellStyle) wb.createCellStyle();
titleSytle.setAlignment(HSSFCellStyle.ALIGN_CENTER_SELECTION);
titleSytle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
Sheet sheet = wb.createSheet("电脑明细表");
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
// Create a row and put some cells in it. Rows are 0 based.
sheet.addMergedRegion(new CellRangeAddress(0,1,0,4));
HSSFRow rt=null;
HSSFCell ct=null;
rt=(HSSFRow) sheet.createRow(0);
ct=rt.createCell(0);
ct.setCellStyle(titleSytle);
ct.setCellValue(new HSSFRichTextString("电脑信息表"));
HSSFCellStyle tableSytle=(HSSFCellStyle) wb.createCellStyle();
tableSytle.setBorderBottom((short)1);
tableSytle.setBorderLeft((short)1);
tableSytle.setBorderRight((short)1);
tableSytle.setBorderTop((short)1);
tableSytle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
Row row0 = sheet.createRow((short)1);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
String[] title=new String[]
{"id","电脑编码","电脑类别","使用店铺","责任人"};
List list=(List) request.getSession().getAttribute("pclist");
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(int i=0;i<title.length;i++)
{
Cell cell = row0.createCell(i);
cell.setCellValue(title[i]);
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(int i=0;i<list.size();i++)
{
Pc pc=new Pc();
pc=(Pc) list.get(i);
Row r = sheet.createRow((short)i+2);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
String[] pcInfo=new String[]
{String.valueOf(pc.getId()),pc.getPcId()
,pc.getPcType(),pc.getShopName(),pc.getUserName()};
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for(int j=0;j<pcInfo.length;j++)
{
Cell c=r.createCell(j);
c.setCellStyle(tableSytle);
c.setCellValue(pcInfo[j]);
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
}
request.setAttribute("wb", wb);
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
return mapping.findForward("excel");
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
action返回了一个excel报表对象后跳转到struts中配置的页面
<action path="/toExcel"
type="com.vle.oa.action.ToExcelAction"
parameter="command"
scope="request">
<forward name="excel" path="/pc/excel.jsp"/>
</action>:
在这里我使用的是struts1,struts2同样原理一样最后编写跳转的jsp
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
<%data:image/s3,"s3://crabby-images/87db9/87db9337486e6758d772829a26342839bc8c1a52" alt=""
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
response.reset();
out.clear();
out=pageContext.pushBody();
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
response.setContentType("application/msexcel");
response.setHeader("Content-disposition","inline; filename=myexcel.xls"); //attachment
HSSFWorkbook wb = (HSSFWorkbook)request.getAttribute("wb");
OutputStream os = response.getOutputStream();
wb.write(os);
os.flush();
os.close();
%>效果如下
data:image/s3,"s3://crabby-images/0f610/0f610b84667953e441c863485fa66a90889aaefc" alt=""
:
data:image/s3,"s3://crabby-images/cb390/cb3905a88affd43d952a3ff8e8a910e026defc73" alt=""