应用MIME将ZPT内容输出为excel文件(word文件)

  MIME (Multipurpose Internet Mail Extensions),意为多目的Internet邮件扩展,它设计的最初目的是为了在发送电子邮件时附加多媒体数据,让邮件客户程序能根据其类型进行处理。然而当它被HTTP协议支持之后,它的意义就更为显著了。它使得HTTP传输的不仅是普通的文本,而变得丰富多彩。
  当浏览器通过各种请求方法,试图从服务器获得数据的时候,服务器就必须将正确的数据返回给浏览器。浏览器并不关心服务器是如何进行处理的,服务器可以返回一个预先编辑好的HTML文档,也能根据请求动态生成返回的数据。而WWW的一大特点就是能用来传送多媒体数据,并且这些数据的传送是完全透明的,通过同样的HTTP连接,可以传送不同格式的声音、图象等数据。当服务器仅仅用于返回静态的HTML文档的时候,浏览器能够很容易的识别其数据类型,但当服务器不但用于返回静态的HTML文档,还可以动态返回各种类型的多媒体信息时,浏览器就不能仅仅从URL请求本身上判断服务器将会返回何种数据了。
  服务器和浏览器之间是采用了另外的方式来标识数据的类型,这种方式下通过在传输真正的数据之前,预先传输一个数据的MIME类型的方法,来标识数据类型。
  最早的HTTP协议中,并没有附加的数据类型信息,所有传送的数据都被客户程序解释为超文本标记语言HTML 文档,而为了支持多媒体数据类型,HTTP协议中就使用了附加在文档之前的MIME数据类型信息来标识数据类型。
  每个MIME类型由两部分组成,前面是数据的大类别,例如声音audio、图象image等,后面定义具体的种类。
  常见的MIME类型如下:
    超文本标记语言文本 .html,.html text/html
    普通文本 .txt text/plain
    RTF文本 .rtf application/rtf
    GIF图形 .gif image/gif
    JPEG图形 .ipeg,.jpg image/jpeg
    au声音文件 .au audio/basic
    MIDI音乐文件 mid,.midi audio/midi,audio/x-midi
    RealAudio音乐文件 .ra, .ram audio/x-pn-realaudio
    MPEG文件 .mpg,.mpeg video/mpeg
    AVI文件 .avi video/x-msvideo
    GZIP文件 .gz application/x-gzip
    TAR文件 .tar application/x-tar
  Internet中有一个专门组织IANA来确认标准的MIME类型,但Internet发展的太快,很多应用程序等不及IANA来确认他们使用的MIME类型为标准类型。因此他们使用在类别中以x-开头的方法标识这个类别还没有成为标准,例如:x-gzip,x-tar等。事实上这些类型运用的很广泛,已经成为了事实标准。只要客户机和服务器共同承认这个MIME类型,即使它是不标准的类型也没有关系,客户程序就能根据MIME类型,采用具体的处理手段来处理数据。而Web服务器和浏览器(包括操作系统)中,缺省都设置了标准的和常见的MIME类型,只有对于不常见的 MIME类型,才需要同时设置服务器和客户浏览器,以进行识别。
  由于MIME类型与文档的后缀相关,因此服务器使用文档的后缀来区分不同文件的MIME类型,服务器中必须定义文档后缀和MIME类型之间的对应关系。而客户程序从服务器上接收数据的时候,它只是从服务器接受数据流,并不了解文档的名字,因此服务器必须使用附加信息来告诉客户程序数据的MIME类型。服务器在发送真正的数据之前,就要先发送标志数据的MIME类型的信息,这个信息使用Content-type关键字进行定义,例如对于HTML文档,服务器将首先发送以下两行MIME标识信息,这个标识并不是真正的数据文件的一部分。
  Content-type: text/html

  注意,第二行为一个空行,这是必须的,使用这个空行的目的是将MIME信息与真正的数据内容分隔开。
  也就是说——当web服务器向一个浏览器返回一个文件时,它发送确定返回内容的类型的信息。当web服务器要产生不只是HTML的内容时,它必须利用Response对象的ContentType属性声明一个MIME类型/子类型。

  综上所述,当我们想要将网页内容输出为excel文件时,标志excel文件的MIME类型/子类型必须在这个页面中进行声明,即利用Response对象的ContentType属性,指示输出是excel文件。
  具体应用范例如下:

ID testSourcePt

Source Code

<html metal:use-macro="here/main_template/macros/master">
<div metal:fill-slot="main">
<body>
<center>
<br>
<a href="testPt2Xls">另存下面的表格为excel文件</a>
<br><br>

<metal:block define-macro="TableText">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

<table border=1>
  <tr>
    <td colspan="4" align="center">
      <h3>This is the Header for a Spreadsheet</h3>
    </td>
  </tr>
  <tr bgcolor="#CCCCCC">
    <td align="center"><b>Text</b></td>
    <td align="center"><b>Date</b></td>
    <td align="center"><b>Time</b></td>
    <td align="center"><b>DateTime</b></td>
  </tr>
  <tr>
    <td align="center">中文测试</td>
    <td align="center">2005-03-22</td>
    <td align="center">09:15:36</td>
    <td align="center">2005-03-22 09:15:36</td>
  </tr>
  <tr bgcolor="#CCCCCC">
    <td align="center"><b>Integer</b></td>
    <td align="center"><b>Float</b></td>
    <td align="center"><b>TAL</b></td>
    <td align="center"><b>FontColor</b></td>
  </tr>
  <tr>
    <td align="center">123456</td>
    <td align="center">3.14159</td>
    <td align="center">
      <span style="color:#00ff00;" tal:content="python:'TAL_OK'">
        <font color="#ff0000">TAL_NO</font>
      </span>
    </td>
    <td align="center">
      <font color="#0000ff">BLUE</font>
      <font color="#CCCC00">ORANGE</font>
      <font color="#ff00ff">PURPLE</font>
    </td>
  </tr>
</table>

</metal:block>

<br><br>
</center>
</body>
</div>
</html>

  我们可以看到,在testSourcePt这个页面模版文件中,我们将页面中的表格描述代码部分定义为宏,这样就可以在其他页面模版文件中根据需求引用该表格。同时需要注意的是,为了使得代码中的中文可以被正确识别,必须在宏所涵盖的代码中对页面代码重新定义。在实际应用中,我们正是通过引用这个宏来实现将宏中所描述的表格输出为excel文件。具体代码如下所示:

ID testPt2Xls

Source Code

<!--MIME类型/子类型声明代码,通知浏览器随后输出的数据为excel文件-->
<tal:x define="a python:context.REQUEST.RESPONSE.setHeader
       ('Content-type','application/vnd.ms-excel')" />
<!--指定所输出文件的文件名,如不指定则默认为当前页面模版的id+".xls"-->
<tal:x define="a python:context.REQUEST.RESPONSE.setHeader
       ('Content-Disposition','attachment;;filename=download.xls')" />

<!--通过使用宏的方式引用其它页面模版中指定宏模块中的页面内容描述代码-->
<metal:block use-macro="container/testSourcePt/macros/TableText" />

  通过定义宏的方式,我们可以实现页面模版文件中“关心内容描述代码”的复用,可以用同一段代码来实现正常web页面的显示需求以及输出excel文件中内容声称需求。
  当然,在没有代码复用需求的情况下,例如仅需要将“关心内容”输出为excel文件,而无需在web页面中显示该内容,则可直接将声明MIME类型/子类型的代码添加到需要输出的页面模版中即可。

  既然已经实现了将“关心内容”输出为excel文件,那么同理很容易就能写出将“关心内容”输出为word文件的代码,对于想要将web页面中内容进行打印却又苦于难于对web页面内容进行排版的兄弟姐妹们有福了。在这里一并给出实现代码如下:

ID testPt2Doc

Source Code

<!--MIME类型/子类型声明代码,通知浏览器随后输出的数据为word文件-->
<tal:x define="a python:context.REQUEST.RESPONSE.setHeader
       ('Content-type','application/vnd.ms-word')" />
<!--指定所输出文件的文件名,如不指定则默认为当前页面模版的id+".doc"-->
<tal:x define="a python:context.REQUEST.RESPONSE.setHeader
       ('Content-Disposition','attachment;;filename=download.doc')" />

<!--通过使用宏的方式引用其它页面模版中指定宏模块中的页面内容描述代码-->
<metal:block use-macro="container/testSourcePt/macros/TableText" />

 来源:http://beauty.hit.edu.cn/myStudy/ProgramNote/document.2006-07-07.5950216136

应用MIME将ZPT内容输出为excel文件(word文件)相关推荐

  1. php表格增加一行数据,““vb中数据库内容输出到excel如何把表格第一行合并添加一个大标题...

    excel表格上面和下面都有行怎么在中间添加一行 excel表面和下面都有行怎么在中间添加一行的方法如下: 1.打开要处理的文档, 2.标定位到要插入的位置之后,比如要在2,3行之间插入,就定位到第3 ...

  2. php datatable导出excel,C#_C#实现将DataTable内容输出到Excel表格的方法,本文实例讲述了C#实现将DataTabl - phpStudy...

    C#实现将DataTable内容输出到Excel表格的方法 本文实例讲述了C#实现将DataTable内容输出到Excel表格的方法.分享给大家供大家参考.具体如下: 1.关于本文 本文描述了一个函数 ...

  3. GridView导出到Excel或Word文件

    在项目中我们经常会遇到要求将一些数据导出成Excel或者Word表格的情况,比如中国移动(我是中国移动用户)网上查话费的页面中就有一个导出到Excel的功能,光大网上银行查看历史明细也有这些功能... ...

  4. 编写代码,实现信用卡诈检测。数据creditcard.csv。要求:使用多种机器学习算法训练模型,并对比结果。根据代和代码果,撰写作业。作业文件格式pdf,把源代码和输出结果拷贝到word文件中,根据

    编写代码,实现信用卡诈检测.数据creditcard.csv.要求:使用多种机器学习算法训练模型,并对比结果.根据代和代码果,撰写作业.作业文件格式pdf,把源代码和输出结果拷贝到word文件中,根据 ...

  5. windows 搜索文件内容 txt 、excel 、word、c、java 、压缩文件 等文件内容

    我的系统是win10,win7好像也可以 方法一 直接在搜索的位置输入 内容:要搜索的文件里面内容的关键字.如下图: 注:这样搜索 只有列出 文件里的内容包含搜索内容的文件,与文件名无关. 方法二 直 ...

  6. Python实现Excel与Word文件中表格数据的导入导出

    封面图片:<Python程序设计实验指导书>(ISBN:9787302525790),董付国,清华大学出版社 图书详情(京东): ============= 问题描述:Excel文件&qu ...

  7. jacob java excel_使用 Jacob 操作Excel、Word文件

    Excel是常用的报表格式,一般系统中要求生成报表,多半都是使用Excel格式.在Java中操作Excel可以使用JavaExcel(jxl)或poi,大部分常用的功能都能实现,也很方便,但生成好的报 ...

  8. 电脑的excel和word文件默认打开方式都变为QQ浏览器打开(修改为wps打开所有格式文件)

    1.看一下用QQ浏览器打开固定格式文件的效果图片 2.解决方案如下 找到电脑的控制面板--所有控制面板--默认程序--设置默认关联 找到固定的文件的格式,双击然后选择默认的打开方式就可以恢复到wps打 ...

  9. pwcorr_a:输出相关系数矩阵至Word和Excel

    原文链接:https://www.lianxh.cn/news/9e0b6ab4954c3.html 目录 功能介绍 使用方法 输出到 Excel 或 Word 文档 补充:Stata 中的 `cor ...

最新文章

  1. 说说JSON和JSONP,也许你会豁然开朗
  2. python浏览器自动化测试库【2018/7/27-更新】
  3. SNMP之管理信息库
  4. 虚函数与纯虚函数的区别
  5. springMvc json 参数
  6. docker安装jenkins并用docker部署net
  7. 用c++自制词法分析器_编译原理笔记 02 词法分析
  8. 第十二章 非对称加密算法-RSA
  9. ×××技术详解(二)
  10. Linux —— 软件安装
  11. 2022年的1024程序员节有啥好玩的小游戏推荐?
  12. app防止被抓包,包括Fiddler,Charles,HttpCanary等工具
  13. python精确有理数实验_有理数类实验报告
  14. IBM Jdk环境启动jboss,出现如下错误:SunX509 KeyManagerFactory not available
  15. 超难打地鼠 【安卓游戏】
  16. 地图下载软件(持续更新)
  17. lol哪个服务器有无限乱斗,英雄联盟无限乱斗和无限火力有什么区别 2021无限乱斗开放时间表[多图]...
  18. Cygwin的简介以及使用方法
  19. canvas水平垂直居中
  20. 麻辣隔壁的我的C币被盗了!?

热门文章

  1. Tensorflow读取图片并转换成张量
  2. leaflet地图原理_leaflet绘制区域(仿高德地图效果)
  3. 通过PCF8591读取电压值(AD转换)
  4. 转: qemu-kvm内存管理
  5. C#中将图片的背景去除
  6. 初出茅庐的SwapX为何可以对垒Uniswap?
  7. 攻击者思维 - iOS 摄像头指示灯不亮,就真的没事了吗?
  8. 屏幕增强字段如何保存修改记录
  9. 如何将3d文件在网页中显示(webGL,three.js)
  10. QML之ubuntu下编译安装虚拟键盘中文输入法