我的做法:用VC做一个ActiveX控件。
解决方案 »
- if(null != name) null放前面的原因
- struts1.配置文件执行
- java service wrapper 实现在linux下jar用 service启动 用过高手的来 急!急!(急!(急!((在线等)
- java-->struts-->jsp的form中输入冷僻中文简体汉字,进入action后从Actionform中取出的中文为乱玛问题,搜不到可行的解决方案,只能弱弱地再问一遍...
- 本地部署war文件能成功,上传到另一服务器Tomcat,webapps目录却不成功!
- 高分求一个struts-layout中<layout:pager>分页的例子!!急啊,两天了
- 关于TOMCAT配置问题??
- 一个bmp和一个cmp要作关联查询,怎么处理
- 请问ec中新建立的tomcat项目的目录下一个文件夹名字是work,这个是放什么的?
- Jboss-tomcat调试servlet出错误?
- 使用MS SQLserver2000,并使用Identity自动增量,造成CMP的ejbCreat()方法出错!请指教!
- 客户端调用EJB,始终提示找不到类
没太明白楼主意思
import jxl.write.*;
import jxl.format.BorderLineStyle;
import java.io.*;
import javax.servlet.http.*;
import javax.servlet.*;
import java.sql.ResultSet;
import java.sql.SQLException;import com.hull.db.pool.SqlServerPool;
import com.hull.tools.StringConverter;/**
* <p>Title: hull</p>
* <p>Description: read and write excel with java</p>
* <p>Copyright: Copyright (c) 2004</p>
* <p>Company: hz-group</p>
* @author wangdong
* @version 1.0
*/public class JExcel extends HttpServlet{
private String excelFilePath;
private WritableWorkbook wbbook;
//private FileOutputStream os;
private OutputStream os;
private WritableCellFormat wcf,wcf_title;
private WritableSheet ws;
private String title;
private int sheetid;
private long shipid;
public void init(ServletConfig config) throws ServletException{
super.init();
excelFilePath = config.getInitParameter("excelFilePath");
if(excelFilePath == null){
throw new ServletException("不能创建excel文件!");
}
}
public void doGet(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException{
response.setContentType("application/vnd.ms-excel");
title = request.getParameter("shipname");
shipid = (new Long(request.getParameter("shipid"))).longValue();
os = response.getOutputStream();
wbbook = Workbook.createWorkbook(os);
sheetid = (wbbook.getSheets()).length;
try{
wcf = new WritableCellFormat();
wcf.setAlignment(Alignment.RIGHT);
wcf.setBorder(Border.ALL,BorderLineStyle.THIN);
wcf.setWrap(true);
wcf_title = new WritableCellFormat();
wcf_title.setAlignment(Alignment.CENTRE);
wcf_title.setBorder(Border.ALL,BorderLineStyle.THIN);
}
catch(WriteException e){
}
ws = wbbook.createSheet(StringConverter.EnToChinese(title),sheetid+1);
ws.setColumnView(0,20);
ws.setColumnView(1,20);
ws.setColumnView(2,20);
ws.setColumnView(3,20);
try{
/**
* 写标题
*/
jxl.write.Label labelTitle = new jxl.write.Label(0,0,StringConverter.EnToChinese(title),wcf_title);
ws.mergeCells(0,0,3,0);
ws.addCell(labelTitle);
/**
* 写入船型内容
*/
SqlServerPool pool = new SqlServerPool();
int i=0,j=1,work=1;
String strsql = "select a.*,b.refvalue from shipref a left join refcontent b on b.refid=a.id "+
"where a.shipid="+shipid+" order by a.reftype desc";
ResultSet rs = pool.executeQuery(strsql);
while(rs.next()){
if(rs.getString("reftype").equals("文本")){
jxl.write.Label typeLabel = new jxl.write.Label(0,j++,rs.getString("refname"),wcf);
ws.addCell(typeLabel);
jxl.write.Label valueLabel = new jxl.write.Label(1,j-1,rs.getString("refvalue"),wcf);
ws.mergeCells(1,j,3,j);
ws.addCell(valueLabel);
}
else{
if(i%2 == 1){
jxl.write.Label typeLabel = new jxl.write.Label(0,j,rs.getString("refname"),wcf);
ws.addCell(typeLabel);
jxl.write.Label valueLabel = new jxl.write.Label(1,j,rs.getString("refvalue"),wcf);
ws.addCell(valueLabel);
}
else{
jxl.write.Label typeLabel = new jxl.write.Label(2,j++,rs.getString("refname"),wcf);
ws.addCell(typeLabel);
jxl.write.Label valueLabel = new jxl.write.Label(3,j-1,rs.getString("refvalue"),wcf);
ws.addCell(valueLabel);
}
work = j;
}
i++;
}
if(work%2 == 1){
jxl.write.Label additional1 = new jxl.write.Label(2,work,"",wcf);
ws.addCell(additional1);
jxl.write.Label additional2 = new jxl.write.Label(3,work,"",wcf);
ws.addCell(additional2);
}
wbbook.write();
wbbook.close();
os.flush();
os.close();
}
catch(Exception ex){
}
}
}
这是一个很强的API,支持xml、cvs导 出,图片插入,表达式 插入等。