asp.net word ecxel类型文件在线预览

首先得引用COM:

Microsoft Excel 10 Object Library

Microsoft Word 10 Object Library

或者是 10以上的类库

我现在用的是:资源下载: http://download.csdn.net/detail/panfuy/3247641 或者附件

Microsoft Excel 10 Object Library

Microsoft Word 10 Object Library

代码如下:

C#代码  

  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Collections;
  5. using System.Web;
  6. using System.Web.Security;
  7. using System.Web.UI;
  8. using System.Web.UI.WebControls;
  9. using System.Web.UI.WebControls.WebParts;
  10. using System.Web.UI.HtmlControls;
  11. using System.IO;
  12. using System.Diagnostics;
  13. using Word = Microsoft.Office.Interop.Word;
  14. using Excel = Microsoft.Office.Interop.Excel;
  15. using System.Reflection;
  16. using Microsoft.Office.Interop.Excel;
  17. public partial class upload_preview : System.Web.UI.Page
  18. {
  19. protected void Page_Load(object sender, EventArgs e)
  20. {
  21. GenerationWordHTML("E://20110502.doc", "E://20110502.html");
  22. GenerationExcelHTML("E://20110502.xls", "E://20110502.html");
  23. }
  24. /// <summary>
  25. /// Ecxel文件生成HTML并保存
  26. /// </summary>
  27. /// <param name="FilePath">需要生成的ecxel文件的路径</param>
  28. /// <param name="saveFilePath">生成以后保存HTML文件的路径</param>
  29. /// <returns>是否生成成功,成功为true,反之为false</returns>
  30. protected bool GenerationExcelHTML(string FilePath, string saveFilePath)
  31. {
  32. try
  33. {
  34. Excel.Application app = new Excel.Application();
  35. app.Visible = false;
  36. Object o = Missing.Value;
  37. ///打开文件
  38. /*下面是Microsoft Excel 9 Object Library的写法: */
  39. /*_Workbook xls = app.Workbooks.Open(FilePath, o, o, o, o, o, o, o, o, o, o, o, o);*/
  40. /*下面是Microsoft Excel 10 Object Library的写法: */
  41. _Workbook xls = app.Workbooks.Open(FilePath, o, o, o, o, o, o, o, o, o, o, o, o, o, o);
  42. ///转换格式,另存为 HTML
  43. /*下面是Microsoft Excel 9 Object Library的写法: */
  44. /*xls.SaveAs(saveFilePath, Excel.XlFileFormat.xlHtml, o, o, o, o, XlSaveAsAccessMode.xlExclusive, o, o, o, o);*/
  45. /*下面是Microsoft Excel 10 Object Library的写法: */
  46. xls.SaveAs(saveFilePath, Excel.XlFileFormat.xlHtml, o, o, o, o, XlSaveAsAccessMode.xlExclusive, o, o, o, o, o);
  47. ///退出 Excel
  48. app.Quit();
  49. return true;
  50. }
  51. catch
  52. {
  53. return false;
  54. }
  55. finally
  56. {
  57. //最后关闭打开的excel 进程
  58. Process[] myProcesses = Process.GetProcessesByName("EXCEL");
  59. foreach (Process myProcess in myProcesses)
  60. {
  61. myProcess.Kill();
  62. }
  63. }
  64. }
  65. /// <summary>
  66. /// WinWord文件生成HTML并保存
  67. /// </summary>
  68. /// <param name="FilePath">需要生成的word文件的路径</param>
  69. /// <param name="saveFilePath">生成以后保存HTML文件的路径</param>
  70. /// <returns>是否生成成功,成功为true,反之为false</returns>
  71. private bool GenerationWordHTML(string FilePath, string saveFilePath)
  72. {
  73. try
  74. {
  75. Word.ApplicationClass word = new Word.ApplicationClass();
  76. Type wordType = word.GetType();
  77. Word.Documents docs = word.Documents;
  78. /// 打开文件
  79. Type docsType = docs.GetType();
  80. Word.Document doc = (Word.Document)docsType.InvokeMember("Open", System.Reflection.BindingFlags.InvokeMethod, null, docs, new Object[] { FilePath, true, true });
  81. /// 转换格式,另存为 HTML
  82. Type docType = doc.GetType();
  83. /*下面是Microsoft Word 9 Object Library的写法: */
  84. /*docType.InvokeMember("SaveAs", System.Reflection.BindingFlags.InvokeMethod, null, doc, new object[] { saveFilePath, Word.WdSaveFormat.wdFormatHTML });*/
  85. /*下面是Microsoft Word 10 Object Library的写法: */
  86. docType.InvokeMember("SaveAs", System.Reflection.BindingFlags.InvokeMethod,
  87. null, doc, new object[] { saveFilePath, Word.WdSaveFormat.wdFormatFilteredHTML });
  88. /// 退出 Word
  89. wordType.InvokeMember("Quit", System.Reflection.BindingFlags.InvokeMethod, null, word, null);
  90. return true;
  91. }
  92. catch
  93. {
  94. return false;
  95. }
  96. finally
  97. {
  98. //最后关闭打开的winword 进程
  99. Process[] myProcesses = Process.GetProcessesByName("WINWORD");
  100. foreach (Process myProcess in myProcesses)
  101. {
  102. myProcess.Kill();
  103. }
  104. }
  105. }
  106. }

asp.net word ecxel类型文件在线预览

时间: 2024-10-05 05:14:24

asp.net word ecxel类型文件在线预览的相关文章

带进度的多文件上传(支持上传.doc后缀的word文档并在线预览)

原文:带进度的多文件上传(支持上传.doc后缀的word文档并在线预览) 源代码下载地址:http://www.zuidaima.com/share/1550463556848640.htm 演示地址:http://img.zeroteam.net/     访问路径和自己工程的设置有关 如:http://localhost:8081/strutd2_fileupload/index.jsp

office文件在线预览,模仿网易邮箱在线预览的

最近研究了半天,代码是倾情奉送啊,C#,asp.net的 这个原理是office文件转换为PDF文件,然后再转换成SWF文件,FlexPaper+swfTools. 有个问题,需要在web.config中加这么一行<identity impersonate="true" userName="administrator" password="你的服务器登录密码" /> /// <summary> /// 转换压缩文件,以便于

java将office文档pdf文档转换成swf文件在线预览

java将office文档pdf文档转换成swf文件在线预览 第一步,安装openoffice.org   openoffice.org是一套sun的开源office办公套件,能在widows,linux,solaris等操作系统上执行. 主要模块有writer(文本文档),impress(演示文稿),Calc(电子表格),Draw(绘图),Math(公式),base(数据库) 笔者下载的是openoffice.org 3.3.0.下载完直接安装即可.      但是,我们还需要启动openof

Aspose office (Excel,Word,PPT),PDF 在线预览

就是做个备份,拿的是试用版的 Aspose         /// <summary>         /// Aspose office (Excel,Word,PPT),PDF 在线预览         /// </summary>         /// <param name="sourceDoc">需要预览的文件地址</param>         /// <param name="saveDoc"&g

.net 实现Office文件预览,word文件在线预览、excel文件在线预览、ppt文件在线预览,excel转html,office格式转换,(.NET、SQL技术交流群206656202,入群需注明来自博客园)

近日公司要搞一个日常的文档管理的东东,可以上传.下载各种文件,如果是office文件呢还必须得支持预览功能,其他的都好说但是唯独office预览功能比较麻烦,但是不能不做,废话不多说了一步步来吧.分析了下网易邮箱的文件预览功能,他用的是微软的组件,最早叫Office online,现在分开了叫Word online.Excel online ....等等,效果十分炫酷功能十分强大,但是查看了下对api的说明发现对服务器的要求比较苛刻而且配置比较复杂不太适合.然后 又看了下腾讯用的是永中第三方组件

word导出html实现在线预览

需要的maven依赖经过编译,必须版本配合一致: <!-- https://mvnrepository.com/artifact/fr.opensagres.xdocreport/org.apache.poi.xwpf.converter.core --> <dependency> <groupId>fr.opensagres.xdocreport</groupId> <artifactId>org.apache.poi.xwpf.convert

前端实现文件在线预览txt,pdf,doc,xls,ppt几种格式

使用iframe标签 1.text,pdf的文件预览 <iframe class="filename" :src="文件的地址" width='100%' height='600' frameborder='1' ></iframe> 2.doc,xls,ppt等office的预览 <iframe class="filename" :src="https://view.officeapps.live.com

word转pdf swf 在线预览

来源:http://www.cnblogs.com/wuhenke/archive/2010/08/01/1789750.html 之前在项目中研究使用了一套word转PDF,然后将PDF转成SWF的方法,最终实现SWF的在线浏览.自己还有些洋洋得意,昨晚在浏览网页搜集资料时发现:原来在2004年左右就有Flash Paper,已经很容易地实现上面的过程. Flash Paper支持Office文档(.doc,.xls,.ppt)直接转换为PDF或SWF,速度很快,效果较好.可惜,Flash P

在线预览Office文件【效果类似百度文库】

引言 结合上个项目和目前做的这个项目,其中都用到了Office文件在线预览,目前项目中是用到公司购买的Ntko控件,该控件每次浏览文件时则会提示安装信任插件,很繁琐,而且浏览效果不好. 提到Office文件在线预览,那么效果最好的应该就是百度文库的效果了,所以今天就忙里偷闲自己搞了下. 用到知识点 1.Office文件转化为Pdf文件.直接用.Net类库:Microsoft.Office.Interop.Excel.Microsoft.Office.Interop.Powerpoint.Micr