哪种方法java导出excell好

Web导出excel的几种方法
我的图书馆
Web导出excel的几种方法
在项目中我们经常遇到需要将报表导出成excel下载保存下来,在不同的要求和不同的资源情况下我们有不同的处理方式。在这里我将谈谈我所遇到的几种情况和遇到的一些问题。
总的来说可以分为:服务器端生成和浏览器端生成2种方法。
一、 服务器端生成就是:根据用户请求,获取相应的数据,使用poi/jxl, jacob/jawin+excel或是用数据拼html的table或是cvs纯文本的数据格式等。然后按.xls或是.cvs格式的文件的形式返回给用户,指定Content-Type:application/vnd.ms-excel ,浏览器就会提示要下载的文件是excel文件。一般情况下采用这种方式的话就可以根据具体要求对excel文件进行细致的处理,各方面样式和排列可以自己控制使用,而且是可以跨平台使用的。缺点就是毕竟需要根据不同的表格进行不断的coding,服务器也有一定的压力,这里我就不进行例子解释了。
二、浏览器端生成excel文件还没有特别完善的方案,这是因为js无法处理二进制。大概有以下几个方案,各有利弊
1.activex方式:使用js调用excel对象,传入需要的参数直接导出excel。
这种方式代码简单,速度较快,前段时间用过2种采用这种方式的方法,各有千秋:
A:页面table拷贝法:
var curTbl = document.getElementById(tableid);&&
&&& var oXL = new ActiveXObject("Excel.Application");
&&& var oWB = oXL.Workbooks.Add();&& //创建AX对象excel&
&&& var oSheet = oWB.ActiveS&& //获取workbook对象&
&&& var sel = document.body.createTextRange();&& //激活当前sheet
&&& sel.moveToElementText(curTbl);&& //把表格中的内容移到TextRange中&&
&&& sel.select();&& //全选TextRange中内容&
&&& sel.execCommand("Copy");& //复制TextRange中内容
&&& oSheet.Paste();&&&&&& //粘贴到活动的EXCEL中&&&&&&&&
&&& oXL.Visible =&& //设置excel可见属性
如上代码可见,这个方法需要传入的就是table的ID,通过拷贝table复制到excel的方式执行,这个方法的特点是可见即所得,当然页面格子大小不能控制精细,只能得到当前页面展示的table部分,如table做了分页处理的话,直接导出的也只是当前页面部分。
B: 页面地址输出法:
var e = new ActiveXObject("Excel.Application");
var b = e.workbooks.open(src);
e.visible =
这个方法更加简单,src为所用导出页面的地址,就直接导出的这张页面为内容的excle,当然src也可以包含参数,但是经过试验,带参数会这页面第一次刷新的时候参数处理有些问题,需要捕获并处理,相信这个方法只导表有些大材小用,因为他导出的是整个页面。.
2.ie命令方式:将html或是csv输出到open的window,然后使用execCommand的saveas命令,存为csv或xls(IE 6 only)
3. 服务器端中转方式:将html的table或是拼接的csv传到服务器端,服务器端再按照Content-Type:application/vnd.ms-excel返回,浏览器就会按excel方式处理。与服务器端拼接相比,少了一次取数操作。
4. data协议方式:对于支持data协议的浏览器,可以将html或是csv先用js base64处理,然后前缀data:application/vnd.ms-base64,,即可使浏览器将其中的数据当做excel来处理,浏览器将提示下载或打开excel文件,可惜的是ie不支持。extjs的官网有一个grid的plugin,实现导出xhtml格式的伪excel文件,就是这么做的。&
浏览器端只有第一种方案导出的是真正的biff格式的excel文件,其他方式都是文本格式。activex方式只能在windows平台的ie浏览器使用,而且需要降低ie的安全性,所以应用比较有限。复杂的excel文件,还是在服务器端用poi/jxl生成excel比较好。如果浏览器固定位ie6,浏览器端方式2是最好的方案。如果要降低服务器端cpu的计算压力,客户端方案3可行,而且跨平台(比poi/jxl方式少了取数和生成二进制文件)。如果是非ie浏览器,方案4也不失为一种好方法。
ps: 还有一个方案,就是让安装了ie和excel的用户在网页上右键,点击“导出到 Microsoft Excel”,然后可以选择要导出的table区域,点“导入”按钮,完成导入。&
TA的最新馆藏[转]&[转]&[转]&博客访问: 1623089
博文数量: 290
博客积分: 5485
博客等级: 大校
技术积分: 3718
注册时间:
多读书,多做事,广交朋友,趣味丛生
IT168企业级官微
微信号:IT168qiye
系统架构师大会
微信号:SACC2013
分类: LINUX
方法一用mysql的命令和shellselect * into outfile './bestlovesky.xls' from bestlovesky where 1 order by id desc& limit 0, 50;方法二 把bestlovesky.xls以文本方式打开,然后另存为,在编码选择ansi编码,保存echo "select id,name from bestlovesky where 1 order by id desc limit 0, 50;"| /usr/local/mysql/bin/mysql -h127.0.0.1-uroot -p123456 > /data/bestlovesky.xls方法三mysql your_database &-uroot &-p &-e &"select&& *&& from&& test.table2 "&& >&& /home/test.xls用sz命令将文件下载到本地,打开如果中文乱码,因为office默认的是gb2312编码,服务器端生成的很有可能是utf-8编码,这个时候你有两种选择,1.在服务器端使用iconv来进行编码转换 iconv -futf8 -tgb2312 -otest2.xls test.xls如果转换顺利,那么从server上下载下来就可以使用了。转换如果不顺利,则会提示:iconv: illegal input sequence at position 1841 类似于这样的错误,先把test.xls下载下来,这个时候文件是utf-8编码的,用excel打开,乱码。把test.xls以文本方式打开,然后另存为,在编码选择ANSI编码,保存。
阅读(27315) | 评论(0) | 转发(0) |
相关热门文章
给主人留下些什么吧!~~
请登录后评论。导出到Excel的7种方法
ange.ange.meRange.Chaactes.Font.FontStyle:='加粗';Temsheet.Cells[TemInt,1]:='入库总额:';Temsheet.Cells[TemInt,3]:=Tim(Edit1.Text);ange:=Temsheet.Range[Temsheet.cells[TemInt,4],Temsheet.cells[TemInt,10]];选表格ange.ange.meTemInt:=TemInt+1;ange:=Temsheet.Range[Temsheet.cells[TemInt,1],Temsheet.cells[TemInt,2]];选表格ange.ange.meRange.Chaactes.Font.FontStyle:='加粗';Temsheet.Cells[TemInt,1]:='出库总额:';Temsheet.Cells[TemInt,3]:=Tim(Edit2.Text);ange:=Temsheet.Range[Temsheet.cells[TemInt,4],Temsheet.cells[TemInt,10]];选表格ange.ange.meTemInt:=TemInt+1;ange:=Temsheet.Range[Temsheet.cells[TemInt,1],Temsheet.cells[TemInt,2]];选表格ange.ange.meRange.Chaactes.Font.FontStyle:='加粗';Temsheet.Cells[TemInt,1]:='总利润:';Temsheet.Cells[TemInt,3]:=Tim(Edit3.Text);ange:=Temsheet.Range[Temsheet.cells[TemInt,4],Temsheet.cells[TemInt,10]];选表格ange.ange.meange:=Temsheet.Range[Temsheet.cells[7,1],Temsheet.cells[TemInt,10]];选定表格ange.odes.linestyle:=1;华线Application.PocessMSceen.Cuso:=CDFExcel.WokBooks[1].saveas(TemFileName);保存文件FExcel.wokooks[1].关闭工作表Application.PocessMMessageBox(Handle,'导出成功','提示',MB_OK);FExcel.visile:=tFExcel.关闭ExcelFExcel:=shellexecute(0,'open',PCha(ExtactFileName(TemFileName)),nil,PCha(ExtactFilePath(TemFileName)),SW_Show);
& 果果文库所有资源均来源于互联网,仅供网友学习交流,若侵犯了您的权益,请联系我们予以删除。
4563&&人浏览
18574&&人浏览
6671&&人浏览
11064&&人浏览
13792&&人浏览
5864&&人浏览
3624&&人浏览
1440&&人浏览
14724&&人浏览
19548&&人浏览
12239&&人浏览
9184&&人浏览
6556&&人浏览
2472&&人浏览
19659&&人浏览
本文标题:导出到Excel的7种方法 链接地址:
copyright@ 2013- Inc. All Rights Reserved 果果文库 版权所有 联系站长: ; 经营许可证编号:浙ICP备号

我要回帖

更多关于 poi导出excel 的文章

 

随机推荐