鸟食轩
Microsoft .NET[C#] MVP 2003
随笔 - 332, 文章 - 870, 评论 - 5722, 引用 - 356
用MIME格式描述多工作表Excel文件
上次说了
使用MIME格式描述多内容的Excel文件
,那么如果我希望描述一个有多工作表(sheet)的Excel文件,是否也同样能办到呢?因为很多时候我们需要把一系列的多个表格导入一个Excel文件中保存,对多工作表的支持是非常重要的功能,否则单Sheet的Excel文件如同鸡肋的说。
其实我们完全可以按照上次的说明,生成一个MIME格式描述的Excel文件先,然后加入对多sheet的描述就可以了。对多sheet支持的MIME描述是文件中一个单独的节,如下是一个描述了4个sheets的节:
------BOUNDARY_9527----
Content-Location: file:///C:/0E8D990C/MimeExcel.xml
Content-Transfer-Encoding: quoted-printable
Content-Type: text/html; charset="us-ascii"
<
html
xmlns:o
=3D"urn:schemas-microsoft-com:office:office"
xmlns:x
=3D"urn:schemas-microsoft-com:office:excel"
xmlns
=3D"http://www.w3.org/TR/REC-html40"
>
<
head
>
<
xml
>
<
x:ExcelWorkbook
>
<
x:ExcelWorksheets
>
<
x:ExcelWorksheet
>
<
x:Name
>
cnblogs
</
x:Name
>
<
x:WorksheetSource
HRef
=3D"cid:sheet001"
/>
</
x:ExcelWorksheet
>
<
x:ExcelWorksheet
>
<
x:Name
>
birdshome
</
x:Name
>
<
x:WorksheetSource
HRef
=3D"cid:sheet002"
/>
</
x:ExcelWorksheet
>
<
x:ExcelWorksheet
>
<
x:Name
>
mime
</
x:Name
>
<
x:WorksheetSource
HRef
=3D"MimeExcel/sheet003.xml"
/>
</
x:ExcelWorksheet
>
<
x:ExcelWorksheet
>
<
x:Name
>
excel
</
x:Name
>
<
x:WorksheetSource
HRef
=3D"MimeExcel/sheet004.xml"
/>
</
x:ExcelWorksheet
>
</
x:ExcelWorksheets
>
</
x:ExcelWorkbook
>
</
xml
>
</
head
>
</
html
>
其实最关键的就是
<
x:WorksheetSource
HRef
=3D"cid:sheet002"
/>
节点,它的属性HRef表示一个Sheet的ID,这个ID和上次说的图片引用一样,可以使Content-Location描述,也可是Content-ID来描述,只要引用的时候注意配对就行了。
各个Sheet的描述就和"
多内容
"一文中说的格式一样。比如sheet001:
------BOUNDARY_9527----
Content-ID: sheet001
Content-Transfer-Encoding: quoted-printable
Content-Type: text/html; charset="us-ascii"
<
html
xmlns:o
=3D"urn:schemas-microsoft-com:office:office"
xmlns:x
=3D"urn:schemas-microsoft-com:office:excel"
xmlns
=3D"http://www.w3.org/TR/REC-html40"
>
<
head
>
<
xml
>
<
x:WorksheetOptions
>
<
x:ProtectContents
>
False
</
x:ProtectContents
>
<
x:ProtectObjects
>
False
</
x:ProtectObjects
>
<
x:ProtectScenarios
>
False
</
x:ProtectScenarios
>
</
x:WorksheetOptions
>
</
xml
>
</
head
>
<
body
>
<
table
>
<
tr
>
<
td
>
cnblogs
</
td
>
<
td
>
cnblogs
</
td
>
<
td
>
cnblogs
</
td
>
<
td
>
cnblogs
</
td
>
</
tr
>
</
table
>
</
body
>
</
html
>
本文MIME Execl文件示例下载:
mime_excel.rar
。显示效果如下图:
绿色通道:
好文要顶
关注我
收藏该文
与我联系
posted on 2005-07-14 00:09
birdshome
阅读(3713)
评论(5)
编辑
收藏
评论
632046
#1楼
回复
引用
查看
楼主的思路非常有启发价值。
楼主的思路本质上是生成mht文件,用IE另存一个网页为mht文件,用Excel是可以正常打开的。
我认为完全自己生成一个mht文件比较麻烦,一般用一个mht文件作为模板,替换内容即可,此模板用Excel制作,另存为mht文件即可。对多个Sheet的文件,如果用楼主生成的模板,改名为mht后在IE中不能正常显示,Excel另存为mht文件时会自动生成框架,在IE中可以正常切换Sheet显示。
2005-07-14 09:49
|
Pharaoh
#2楼
回复
引用
查看
mark...
多谢楼主!
2005-07-14 10:07
|
阿浪
#3楼
回复
引用
查看
不错,支持ing
2005-07-14 12:29
|
Eunge
#4楼
回复
引用
用MIME生成Excel文件是否有大小限制或者sheet数限制?如果有,是否可能突破?
尝试用MIME生成多sheet的Excel文件,当文件大小超过1M,或者sheet数超过10个的时候,Office2003打开该Excel文件会报错,打开失败。
用Office2002可以打开,但是如果文件名超过9位(中文、英文都一样)时,就会报错。
用MIME生成Excel文件是否有限制?
2007-01-27 16:56
|
九门提督[未注册用户]
#5楼
[
楼主
]
回复
引用
查看
@九门提督
我没有生成过如此大规模的MIME格式Excel文档,你可以这样试验一下。先生成一个简单的Excel文件,让其远远超过10个Sheets,但是每个Sheet很简单,这样文件远小于1M,另存为mht,看看能不能打开?二是生成一个只有1个或2个Sheets的Excel文档,让每个Sheet很复杂,让文件远大于1M,也另存为mht,再看看能不能打开?
2007-01-27 17:08
|
birdshome
注册用户登录后才能发表评论,请
登录
或
注册
,
返回博客园首页
。
首页
博问
闪存
新闻
园子
招聘
知识库
最新IT新闻
:
·
最想要的Entity Framework功能
·
专访Jeffrey Richter:Windows 8是微软的重中之重
·
《福布斯》:谷歌进军硬件产品 难撼动苹果地位
·
美国空军拟最多购买1.8万台iPad 2
·
分析称专利之争让谷歌苹果两败俱伤
»
更多新闻...
最新知识库文章
:
·
高级编程语言的发展历程
·
如何学习一门新的编程语言?
·
学习不同编程语言的重要性
·
为什么我喜欢富于表达性的编程语言
·
计算机专业的女生为什么要学编程
»
更多知识库文章...
China-pub 2011秋季教材巡展
China-Pub 计算机绝版图书按需印刷服务
导航
博客园
首页
新随笔
联系
订阅
管理
公告
Invert
原创
技术文章和心得,
转载
必须注明来源
"博客园"
!
贴子以"现状"提供,且没有任何担保,同时也没有授予任何权利。
昵称:
birdshome
园龄:
7年10个月
荣誉:
推荐博客
粉丝:
73
关注:
3
搜索
常用链接
我的随笔
我的评论
我的参与
最新评论
我的标签
我的标签
Nokia 6300
(2)
fan
(1)
qq
(1)
腾讯
(1)
输入法
(1)
隐私
(1)
随笔分类
(337)
.NET的私有工具类(2)
(rss)
.NET技术开发相关(34)
(rss)
Asp.net控件开发(14)
(rss)
Debug中的滑铁卢(9)
(rss)
Enjoy Computer :)(27)
(rss)
Jscript&Dhtml开发(162)
(rss)
技术区里的非技术(49)
(rss)
开发中遇到的虫子(14)
(rss)
其它编程相关内容(16)
(rss)
商务智能(BI)开发(10)
(rss)
文章分类
(147)
北京的幸福生活(29)
(rss)
不得不转载(19)
(rss)
乖乖的文章(6)
(rss)
那时还没有blog(4)
(rss)
那是相当八卦(10)
(rss)
手机短信息(1)
(rss)
我们的文章(40)
(rss)
珍贵照片的背景(4)
(rss)
重庆的幸福生活(34)
(rss)
相册
2005 Kick Off @ 涞滩
2006 Kick Off @ 钓鱼城
2006 Offsite @ 四面山
2006 Wedding @ 昆明
2007 Marriage @ 哈尔滨
2007 Offsite @ Thailand
2007 Offsite @ 海南云天
2007 Training @ Seattle
2007 Travelling @ 云南
2008 Travelling @ 天津
乱七八糟的收集
Ex-Colleagues
Jason Lei's Space
.Net Life
(rss)
Jasper
(rss)
Michelles Space
xingd.net
(rss)
玻璃缸
(rss)
短鲷生活
海阔天空
录一室
(rss)
完美的泡菜
(rss)
怡红公子
(rss)
竹叶尖的BLOG
常用链接
Engadget 中文版
PDFCHM eBooks
SitePoint Forums
The Code Project
安利上海直销店
哈尔滨工业大学
哈工大紫丁香
海归论坛
(rss)
沙坪坝区中医院
兄弟情深
没有可乐的日子
葡萄树下不乘凉
(rss)
斯普特尼克
猪头小队长
(rss)
积分与排名
积分 - 3145044
排名 - 6
最新评论
阅读排行榜
推荐排行榜