乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > <em>js</em>如何把<em>table</em>转成<em

<em>js</em>如何把<em>table</em>转成<em

作者:乔山办公网日期:

返回目录:excel表格制作


什么是HTML格式的EXCEL呢?
你打开一个Excel文件,另存为Html格式,就知道

Response.ContentType 是告诉浏览器,服务器传递过来的内容是什么格式
这个值默认是text/html

这个要在所有的客户机上设置浏览器权限,比如IE的修改方法:
进入Internet属性=》安全=》自定义级别,把ActiveX控件和插件下的所有选项都改成启用

因为js是客户端的,所以服务器不可能控制

我一般是用服务器生成html格式的Excel,然后设置
Response.ContentType = "application/vnd.ms-excel";
Response.AppendHeader("Content-Disposition", "inline;filename=abc.xls");

这样来下载excel,而且这样不用修改客户端的ie设置

无非是这样的一个过程。先通过数据库查询出数据,放到List里,然后把这个List发往页面,然后遍历这个List把数据显示到这个表格里。 要想把数据导出到execel,很简单,把页面接受的这个List用jxl写到Execel就行了。具体将List导出到Execel的类如下:

package cms.dao;
import java.io.IOException;
import java.io.OutputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
import jxl.Workbook;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import cms.utlis.DbUtils;
public class ToExecelByQuery {
//方法接受两个参数,一个是list,这个地方我7a686964616fe78988e69d83363用了泛型。另一个参数是HttpServletResponse response
public static void toExcelBy(List<AccessLog> list,HttpServletResponse response) {
// 创建工作表
WritableWorkbook book=null;
response.reset();
// 创建工作流
OutputStream os =null;
try {
// 设置弹出对话框
response.setContentType("application/DOWLOAD");
// 设置工作表的标题
response.setHeader("Content-Disposition",
"attachment; filename=****.xls");//设置生成的文件名字
os = response.getOutputStream();

// 初始化工作表
book = Workbook.createWorkbook(os);

} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
try{
//以下是我做的导出日志的一个模版
int nCount = list.size();
WritableSheet sheet = book.createSheet("访问日志", 0);
// 生成名为"商品信息"的工作表,参数0表示这是第一页
int nI = 1;
// 表字段名
sheet.addCell(new jxl.write.Label(0, 0, "日志编号"));
sheet.addCell(new jxl.write.Label(1, 0, "用户ID"));
sheet.addCell(new jxl.write.Label(2, 0, "用户姓名"));
sheet.addCell(new jxl.write.Label(3, 0, "访问日期"));
sheet.addCell(new jxl.write.Label(4, 0, "访问时间"));
sheet.addCell(new jxl.write.Label(5, 0, "名片ID"));
sheet.addCell(new jxl.write.Label(6, 0, "名片名称"));
sheet.addCell(new jxl.write.Label(7, 0, "创建日期"));
sheet.addCell(new jxl.write.Label(8, 0, "更新日期"));
// 将数据追加
for(int i=1;i<list.size();i++){

sheet.addCell(new jxl.write.Label(0, i, list.get(i).toString()));
sheet.addCell(new jxl.write.Label(1, i, list.get(i).getUserId()));
sheet.addCell(new jxl.write.Label(2, i, list.get(i).getUsername()));
sheet.addCell(new jxl.write.Label(3, i, list.get(i).getCrtTim()));
sheet.addCell(new jxl.write.Label(4, i, list.get(i).getComplTime()));
sheet.addCell(new jxl.write.Label(5, i, list.get(i).getCopId()));
sheet.addCell(new jxl.write.Label(6, i, list.get(i).getFirstname()));
sheet.addCell(new jxl.write.Label(7, i, list.get(i).getCrtTim()));
sheet.addCell(new jxl.write.Label(8, i, list.get(i).getUpdTim()));

}
book.write();
book.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
上面的7a686964616fe4b893e5b19e364是打印的,发错了。
<html<head<meta http-equiv= Content-Type content= text/html; charset=GBK
<title ActiveX </title<styletable { border-color: silver red RGB(223, 94, 77) black; border: 25px;}</style<script type= text/javascript
//打开已存在的Excel表格
function openExcel(file){var Excel = new ActiveXObject( Excel.Application );
Excel.Visible = false;
ActiveSheet = Excel.Workbooks.Open(file).ActiveSheet;
Excel.Cells.Select;
Excel.Selection.Copy();
document.all.editdiv.focus();
rang = document.selection.createRange();
rang.execCommand( Paste );
//document.all.editdiv.innerHTML = ActiveSheet.Cells(1, 1).Value;
//Excel.Visible = true;
Excel.Quit();//关闭}//openWord( D:/1.doc );
</script</head<body<form action=
<noscript <div id= noscript_msg class= msg 您需要启动JavaScript,才能使用本网页。 </div </noscript
<div id= editdiv contenteditable=true style= width:400;height:300; </div</form</body</html这样做,是可以把内容复制下来,但是却没有边框。要想要好一些的效果,估计就得自己循环取值,付给table了。

ECXEL不同于SQL。EXCEL中所说的表,实际是表的标签名称。而你所说那个数组公式里看也没有表名后面的!和计算函数。而目前EXCEL版本中没有TABLE这个函数。如果想更快解决问题,您的描述要更清楚一点。还有可能是自定义函数。这要看看你的文件再说。

相关阅读

  • <em>js</em>如何把<em>table</em>转成<em

  • 乔山办公网excel表格制作
  • 什么是HTML格式的EXCEL呢?你打开一个Excel文件,另存为Html格式,就知道百了Response.ContentType 是告诉浏览器,服务器传递过来的内容是什么格式这个值默认是度text/html这个要在所有的客户