一、怎么在jsp中打开显示excel
需要导出的文件头上加:
---------------------------------------------------------------
使用OFFice WEB Components
---------------------------------------------------------------
在页首加上
---------------------------------------------------------------
header("Content-type: application/msexcel");
header("Content-Disposition: attachment; filename=aaa.xls");?>filename=aaa.xls这个是默认下载的文件名;
application/unknown这个是指定当前页面生成的文件类型,这可以对应着windows里的MIME类型名称;
如是指定是word文档,你可以设置“application/msword”,指定是excel文档,你可设置“application/msexcel”。
二、jsp怎么才能直接显示word文档、excel文档
1、没必要存进数据库。要存数据库的话,要么就把excel转为byte存进去,但这样做还不如直接放服务器上,,就像图片一样,在数据库存个路径就好了;要么把excel的内容读出来,在数据库建相应的表,再存进去,这样麻烦,也不灵活,要设计表,而且当你要改excel表的结构时,数据库表也得改。
2、在jsp中显示,最简单的思路是,遍历excel表,把内容逐个拿出来,再写到<td>;里,不过如果excel表结构太复杂的话,做起来就相当麻烦了。
3、至于像如意报表、华表那些报表工具有没有将excel转换为html的功能,就不知道了,没用过,楼主可以上网搜索一下。
下面是一位叫张丽鹏写的代码,我稍微修改了一下
import jxl.*;
import java.io.*;
import jxl.write.*;
public class Test1 {
public static void main(String[] args) {
jxl.Workbook rwb = null;
try{
//构建Workbook对象, 只读Workbook对象
//直接从本地文件创建Workbook
//从输入流创建Workbook
InputStream is = new FileInputStream("D:/jb9Test/MyExcelTest/Book1.xls");
rwb = Workbook.getWorkbook(is);
//Sheet(术语:工作表)就是Excel表格左下角的Sheet1,Sheet2,Sheet3但在程序中
//Sheet的下标是从0开始
//获取第一张Sheet表
Sheet rs = rwb.getSheet(0);
//获取Sheet表中所包含的总列数
int rsColumns = rs.getColumns();
//获取Sheet表中所包含的总行数
int rsRows = rs.getRows();
//获取指定单元格的对象引用
//要在jsp页面显示的话,就改下面这个循环的代码,麻烦的是要考虑<tr>;、<td>;的嵌套
for(int i=0;i<rsRows;i++){
for(int j=0;j<rsColumns;j++){
Cell cell = rs.getCell(j,i);
//拿到表格的内容,并打印
System.out.print(cell.getContents()+" ");
}
System.out.println();
}
} catch(Exception e) {
e.printStackTrace();
} finally{
//操作完成时,关闭对象,释放占用的内存空间
if(rwb != null) {
rwb.close();
}
}
}
}
三、如何在JSP页面中显示指定EXCEL中的内容
<;用servlet>
在servlet的servlet里面写入
response.setcontentType("application vnd msexcel");
PrintWriter out=response.Writer();
out.print("\t q1 \t q2");
out.print("\t q3 \t q4");
q1。.代表你输出的类容,,我一般不答题,,希望你看到答案就给分
四、如何使用jsp实现word、excel格式报表打印
因为ms word和excel的文档都支持html文本格式,因此可以先用word或excel做好模版,另存为Web页,然后将该html改成jsp,将数据部分动态填入即可,不用很辛苦的调整格式 word页面只要在jsp头设置如下指令: <%@page contentType="application/msword;charset=utf-8" %> excel如下: <%@page contentType="application/vnd.ms-excel;charset=utf-8" %> 使用这种方式客户端必须安装有office软件,用户访问时将在ie中直接用word或excel打开该页面。
此方法优势是模板设计、调整方便,无需在服务器端使用复杂的POI或jxl技术,也无需在客户端使用ActiveX控件技术,更安全、方便,轻松实现较好的打印效果。 microsoft关于服务器端动态创建office文档的资料(asp示例): http://support.microsoft.com/default.aspx?scid=KB;en-us;301044& 简单示例: 使用word建立一文档,画表格如下: ---------------------------- | 用户名 | 真实姓名 | 性别 | ---------------------------- | guest | 路人甲 | 男 | ---------------------------- 保存为Web页test.htm, 将test.htm改名为test.jsp,修改其中guest、路人甲、男为从数据库动态查询,如下: <%@ page contentType="application/msword;charset=utf-8" %> <%@ page import="java.sql.*" %>
| 用户名 |
静夜_思