总的来说,两种方法:服务器端生成和浏览器端生成。

服务器端生成就是:根据用户请求,获取相应的数据,使用poi/jxl, jacob/jawin+excel,或是用数据拼html的table或是cvs纯文本的数据格式等。然后按.xls或是.cvs格式的文件的形式返回给用户,指定Content-Type:application/vnd.ms-excel ,浏览器就会提示要下载的文件是excel文件。

poi/jxl, jacob/jawin生成的是excel的biff格式。html/csv的是文本格式,不另存为excel文件,很多excel功能是用不了的。jacob/jawin需要服务器端是windows系统,且安装了excel2000以上版本。poi/jxl和html/csv方式的话,服务器端可以跨平台。

浏览器端生成excel文件还没有特别完善的方案,这是因为js无法处理二进制。大概有以下几个方案,各有利弊。

1. activex方式:使用js/vbs调用excel对象,http://setting.javaeye.com/blog/219302,有个extjs的gridpanel导出为excel的例子。 (ie+excel)

2. ie命令方式:将html或是csv输出到open的window,然后使用execCommand的saveas命令,存为csv或xls。 (ie6 only)

3. 服务器端中转方式:将html的table或是拼接的csv传到服务器端,服务器端再按照Content-Type:application/vnd.ms-excel返回,浏览器就会按excel方式处理。与服务器端拼接相比,少了一次取数操作。 (all)

4. data协议方式:对于支持data协议的浏览器,可以将html或是csv先用js base64处理,然后前缀data:application/vnd.ms-excel;base64,,即可使浏览器将其中的数据当做excel来处理,浏览器将提示下载或打开excel文件,可惜的是ie不支持。extjs的官网有一个grid的plugin,实现导出xhtml格式的伪excel文件,就是这么做的。 (except IE)

浏览器端只有第一种方案导出的是真正的biff格式的excel文件,其他方式都是文本格式。activex方式只能在windows平台的ie浏览器使用,而且需要降低ie的安全性,所以应用比较有限。复杂的excel文件,还是在服务器端用poi/jxl生成excel比较好。如果浏览器固定位ie6,浏览器端方式2是最好的方案。如果要降低服务器端cpu的计算压力,客户端方案3可行,而且跨平台(比poi/jxl方式少了取数和生成二进制文件)。如果是非ie浏览器,方案4也不失为一种好方法。

ps: 还有一个方案,就是让安装了ie和excel的用户在网页上右键,点击“导出到 Microsoft Excel”,然后可以选择要导出的table区域,点“导入”按钮,完成导入。

转自:http://www.javaeye.com/topic/461899

web导出excel文件的几种方法(转)相关推荐

  1. web导出excel文件的几种方法

    KimmKing kimmking@163.com 2009年9月4日10:19:09 总的来说,两种方法:服务器端生成和浏览器端生成. 服务器端生成就是:根据用户请求,获取相应的数据,使用poi/j ...

  2. SAS导出EXCEL文件的几种方法

    SAS学习 SAS导出EXCEL文件的几种方法 以下基于SAS 9.3简体中文版 一.proc export proc export data=a.dataname outfile='D:\excel ...

  3. .NET CORE 2.1 导出excel文件的两种方法

    最近在做 MVC 项目的时候遇到项目的导出,下面总结下两种导出到excel 的方法 第一种方法: 将文件写到本地,然后返回这个File 或者返回这个 File 的绝对地址  其中  _hostingE ...

  4. php原生导出excel文件的两种方法

    第一种方法: $filename='文件名称';$filetitle='你的标题';if($_POST){set_time_limit(10000):$title = '';ini_set('memo ...

  5. Ruby读取Excel文件的两种方法

    用Ruby读取Excel文件的两种重要方式 1. 通常做法,查阅微软提供的API了,需要包含win32, 在ruby前加入,require 'win32ole' 例如: require 'win32o ...

  6. ASP导出Excel数据的四种方法

    一.使用OWC 什么是OWC? OWC是Office Web Compent的缩写,即Microsoft的Office Web组件,它为在Web中绘制图形提供了灵活的同时也是最基本的机制.在一个int ...

  7. C# 导出excel文件的6种办法

    原博客链接:https://blog.csdn.net/huoliya12/article/details/90645036 为防止遗忘,所以进行摘录,原文介绍有8种,感兴趣的查看原文. 1.使用Mi ...

  8. PHP 导出excel表格的3种方法

    方法一: 优点:样式好看一点,有表头,缺点:还要手动编辑表的第一行($column),代码量也比较多一点 public function testdaochu1(){$file_name = '模板' ...

  9. office是不是python的打开方式_python打开excel文件的2种方法(基于win32com)

    excel文件打开,会遇到两种不通的场景:excel文件还没有打开,直接打开操作 文件一定打开,需要脚本获取到已打开的文件,然后再操作 [1]直接打开 import win32com.client a ...

  10. Java web导出excel文件 - poi

    Javaweb项目加入导出excel功能只需要2个步骤: 1.在需要的controller里面加入下面接口代码: /*** excel导出controller层代码** @param params* ...

最新文章

  1. java二维数奇数组金字塔_金字塔内发现一组神奇数字 至今无解(图)
  2. spring事务配置,声明式事务管理和基于@Transactional注解的使用
  3. nginx linux源码编译安装,Linux源码编译安装nginx
  4. 给基于SAP Spartacus 3.4.1 版本的 Storefront 添加对服务器端渲染的支持
  5. php如何按降序,PHP数组如何按键名实现降序排列
  6. 复习一下日志等级类型
  7. poj 3101Astronomy(圆周追击+分数最小公倍数)
  8. Java 9 接口私有方法
  9. vue vue实例中的data与vue组件中的data()
  10. java web js_JAVA Web JS
  11. pandas根据列值读取行
  12. 第十一届蓝桥杯省赛B组真题训练
  13. 按键精灵操作mysql数据库_按键精灵mysql数据库
  14. iOS14.7 验证失败,因为您不再连接到互联网
  15. Microsoft Office下载链接
  16. 【思考】关于英语论文写作的底层逻辑思考
  17. Python笔记之自定义函数
  18. android 手机系统占用存储,5分钟读懂手机系统文件清理,64G内存也能当作256G使用...
  19. 日本研制超音速小飞机或达音速2倍
  20. 马斯洛需求:互联网产品设计的理论支点

热门文章

  1. Java2实用教程第五版课后习题解析(持续更新,适合初学者)
  2. 命题逻辑——自由之门与死亡之门
  3. QQ音频文件服务器,unlock-music:支持解密网易云/QQ音乐的加密文件和ID3信息补全...
  4. java单元测试方法的使用
  5. CSDN博客代码高亮显示
  6. Windows server服务器FTP设置以及客户端FlashFXP连接FTP
  7. Oracle 11g数据库基础教程(第2版)-课后习题-第十三章
  8. Teamviewer远程连接(Win和Linux下teamviewer软件互连)
  9. SQL必知必会知识点汇总
  10. DB破解(暗黑破坏神辅助)使用方法