亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#實現將PPT轉換成HTML的方法

2020-01-24 02:34:10
字體:
來源:轉載
供稿:網友

本文是一個C#的小程序,主要實現將ppt轉換成html的功能,方法很多,此處與大家分享一下,希望能對大家的項目開發起到一定的借鑒作用。

主要功能代碼如下:

using System; using System.Collections.Generic; using System.Text; using System.IO; using PPT = Microsoft.Office.Interop.PowerPoint; using System.Reflection;namespace WritePptDemo {   class Program   {     static void Main(string[] args)     {       string  path;     //文件路徑變量       PPT.Application pptApp;   //Excel應用程序變量        PPT.Presentation pptDoc;   //Excel文檔變量       PPT.Presentation pptDoctmp;      path  = @"C:/MyPPT.ppt";   //路徑       pptApp =  new PPT.ApplicationClass();  //初始化      //如果已存在,則刪除       if  (File.Exists((string)path))       {          File.Delete((string)path);       }      //由于使用的是COM庫,因此有許多變量需要用Nothing代替       Object  Nothing = Missing.Value;       pptDoc =  pptApp.Presentations.Add(Microsoft.Office.Core.MsoTriState.msoFalse);        pptDoc.Slides.Add(1,  Microsoft.Office.Interop.PowerPoint.PpSlideLayout.ppLayoutText);       string text = "示例文本";      foreach  (PPT.Slide slide in pptDoc.Slides)       {          foreach (PPT.Shape shape in slide.Shapes)          {            shape.TextFrame.TextRange.InsertAfter(text);          }       }        //WdSaveFormat為Excel文檔的保存格式        PPT.PpSaveAsFileType format = PPT.PpSaveAsFileType.ppSaveAsDefault;      //將excelDoc文檔對象的內容保存為XLSX文檔         pptDoc.SaveAs(path, format, Microsoft.Office.Core.MsoTriState.msoFalse);      //關閉excelDoc文檔對象         pptDoc.Close();      //關閉excelApp組件對象         pptApp.Quit();       Console.WriteLine(path + " 創建完畢!");       Console.ReadLine();       string  pathHtml = @"c:/MyPPT.html";       PPT.Application pa = new PPT.ApplicationClass();       pptDoctmp = pa.Presentations.Open(path,  Microsoft.Office.Core.MsoTriState.msoTrue,  Microsoft.Office.Core.MsoTriState.msoFalse,  Microsoft.Office.Core.MsoTriState.msoFalse);        PPT.PpSaveAsFileType formatTmp = PPT.PpSaveAsFileType.ppSaveAsHTML;        pptDoctmp.SaveAs(pathHtml, formatTmp,  Microsoft.Office.Core.MsoTriState.msoFalse);        pptDoctmp.Close();       pa.Quit();        Console.WriteLine(pathHtml + " 創建完畢!");     }   } } 

以上程序是使用C# 先創建一個ppt 文件并向里面寫入了文字,然后再把此ppt 轉換成html  ,對于上面程序需要說明的其實就是

引用dll的問題, 在項目中添加引用,在com 組件中選擇 microsoft powerpoint 11.0 object   library ,而如果你的電腦沒有安裝 office 2003 是不會有這個的,而如果安裝的是office 2007 則是microsoft powerpoint 12.0 object   library。而且即使你引用成功后,還是會編譯不通過,是因為少安裝了 office   PIA  ,在安裝office 時,如果你是選擇的典型安裝是不會安裝這個的,因為這個只針對開發人員才會用到。可以到網上下載一個 office PIA 安裝下就ok了
 
Office文件轉換成Html格式功能代碼如下:  

 using  Microsoft.Office.Core; using Microsoft.Office.Interop.PowerPoint;using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Web; using System.IO; using System.Text.RegularExpressions; using Nd.Webs; using Aspose.Cells; using Aspose.Words; using ND.CommonHelper; using Microsoft.Office.Interop.PowerPoint; using Microsoft.Office.Core;namespace Api.Note.Base {   #region Office文件轉換成Html格式   class OfficeHtmlBo   {     #region InsertHeadHtml     /// <summary>     /// InsertHeadHtml     /// </summary>     /// <param  name="WordFilePath">InsertHeadHtml</param>     private string  InsertHeadHtml(string strHtml, string realPath)     {       int index  = strHtml.IndexOf("<body");       strHtml =  strHtml.Insert(index, "<div  style='height:60px;font-size:14px;margin:0px 0px  12px 0px;padding:14px 4px 12px 12px;line-height:24px;height:1%;'>以下是該文檔的HTML預覽效果。<br/><span>由于是網頁提取顯示word中的內容,有可能部分顯示與源文檔中有差異,如想查看更準確的信息,</span>您可以點擊 <a  style='color:6699FF;text-decoration:underline;'  href='/Lib/UdControls/Download.aspx?action=Download&appFormCode=" +  HttpContext.Current.Request.QueryString["appFormCode"].ToString() +  "&path=" +  HttpContext.Current.Request.QueryString["path"].ToString() +  "&encrypt=" + HttpContext.Current.Request.QueryString["encrypt"].ToString()  + "'><b>下載原始附件</b></a></div>");      Regex  reg = new  Regex(@"(?<start><img[^>]+?src="")(?<src>[^""]+?)(?<end>""[^>]+?>)");       strHtml =  reg.Replace(strHtml, delegate(Match m)       {          return string.Format("{0}{1}{2}{3}",            m.Groups["start"].Value,            realPath,            m.Groups["src"].Value,            m.Groups["end"].Value            );       });       return strHtml;     }     #endregion    #region GetLeftStr     /// <summary>     /// 截取字符串左邊指定長度     /// </summary>     /// <param  name="str"></param>     /// <param  name="length"></param>     ///  <returns></returns>     public string GetLeftStr(string  str, int length)     {       length =  length * 2;       string  tempStr = "";       int i = 0;       foreach  (char c in str)       {          tempStr += c.ToString();          if (((int)c >= 33) && ((int)c <= 126))          {            //字母和符號原樣保留             i += 1;          }          else          {            i += 2;          }          if (i >= length)          {            return tempStr;          }       }       return  str;     }     #endregion    #region 將Word文檔轉換成HTML格式     /// <summary>     /// 將Word文檔轉換成HTML格式     /// </summary>     /// <param  name="WordFilePath">Word文檔格式</param>     private void WordToHtmlFile(string  WordFilePath)     {       try       {          // 指定原文件和目標文件          string realPath = WordFilePath.Substring(0,  WordFilePath.LastIndexOf("/") + 1);          WordFilePath = System.Web.HttpContext.Current.Server.MapPath(WordFilePath);          object target = WordFilePath.Substring(0,  WordFilePath.LastIndexOf(".")) + ".html";          //string realPath = WordFilePath.Substring(0,  WordFilePath.LastIndexOf(".")) + ".html";         if (!File.Exists(target.ToString()))          {            Document doc = new Document(WordFilePath);            doc.Save(target.ToString(), SaveFormat.Html);          }         StreamReader sr = new StreamReader(target.ToString(), Encoding.Default);          string strHtml = sr.ReadToEnd();         strHtml = InsertHeadHtml(strHtml, realPath);          HttpContext.Current.Response.Write(strHtml);         sr.Close();       }       catch  (Exception ex)       {          //記錄異常          LogEntry logEntry = new LogEntry();          logEntry.Message = ex.Message;          logEntry.Title = "---->將Word文檔轉換成HTML格式異常[WordToHtmlFile]";          logEntry.TimeStamp = DateTime.Now;          logEntry.LogEntryType = LogEntryType.Error;          logEntry.LogCatalog = LogCatalog.ExceptionLog;          logEntry.StackTrace = ex.StackTrace;          LogPosition logPosition = LogPosition.FileLog;          string positionParameter =  SysConfig.ToString(SysConfig.GetAppSetting("LogPath"));          SysLogger.Write(logEntry, logPosition, positionParameter);       }     }     #endregion    #region 將Excel文件轉換成HTML格式     /// <summary>     /// 將Excel文件轉換成HTML格式     /// </summary>     /// <param  name="ExcelFilePath">Excel文件路徑</param>     private void  ExcelToHtmlFile(string ExcelFilePath)     {       try       {          string realPath = ExcelFilePath.Substring(0,  ExcelFilePath.LastIndexOf("/") + 1);          int index = ExcelFilePath.LastIndexOf("/");          string fileName;          if (ExcelFilePath.IndexOf(":") != -1)          {            fileName = ExcelFilePath.Split(new char[] { ':' })[0].ToString();            fileName = GetLeftStr(fileName.Substring(0,  fileName.LastIndexOf(".")), 10) +  fileName.Substring(fileName.LastIndexOf("."));            fileName = HttpUtility.UrlEncode(fileName, Encoding.UTF8);          }          else          {            fileName = ExcelFilePath.Substring(index + 1, ExcelFilePath.Length - index -  1);            fileName = GetLeftStr(fileName.Substring(0,  fileName.LastIndexOf(".")), 10) +  fileName.Substring(fileName.LastIndexOf("."));            //編碼            fileName = HttpUtility.UrlEncode(fileName, Encoding.UTF8);          }          fileName = fileName.Substring(0, fileName.LastIndexOf("."));          ExcelFilePath = System.Web.HttpContext.Current.Server.MapPath(ExcelFilePath);          //目標html文件路徑          object target = ExcelFilePath.Substring(0,  ExcelFilePath.LastIndexOf(".")) + ".html";         string target2 = ExcelFilePath.Substring(0,  ExcelFilePath.LastIndexOf("http://")) + "http://" + fileName +  "_files//sheet001.htm";          if (!File.Exists(target.ToString()))          {            //為了保險,只讀方式打開             //object readOnly = true;            //// 指定另存為格式(html)             //object format = Microsoft.Office.Interop.Excel.XlFileFormat.xlHtml;           ////打開Excel文件            //oBook = excelApp.Workbooks.Open(ExcelFilePath, Unknown, readOnly,            //  Unknown, Unknown, Unknown, Unknown, Unknown, Unknown,            //  Unknown, Unknown, Unknown, Unknown, Unknown, Unknown);           //// 轉換格式             //oBook.SaveAs(target, format, Unknown, Unknown, Unknown, Unknown,            //    Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,            //   Unknown, Unknown, Unknown, Unknown, Unknown);           Workbook wBook = new Workbook();            wBook.Open(ExcelFilePath);            wBook.Save(target.ToString(), FileFormatType.Html);          }         StreamReader sr = new StreamReader(target2.ToString(), Encoding.Default);          string strHtml = sr.ReadToEnd();         strHtml = InsertHeadHtml(strHtml, realPath);         strHtml = strHtml.Replace("window.location.replace", "");          strHtml = strHtml.Replace("filelist.xml", realPath + "/"  + fileName + "_files/filelist.xml");          strHtml = strHtml.Replace("stylesheet.css", realPath +  "/" + fileName + "_files/stylesheet.css");          HttpContext.Current.Response.Write(strHtml);         sr.Close();       }       catch  (Exception ex)       {          //記錄異常          LogEntry logEntry = new LogEntry();          logEntry.Message = ex.Message;          logEntry.Title = "---->將Excel文件轉換成HTML格式[ExcelToHtmlFile]";          logEntry.TimeStamp = DateTime.Now;          logEntry.LogEntryType = LogEntryType.Error;          logEntry.LogCatalog = LogCatalog.ExceptionLog;          logEntry.StackTrace = ex.StackTrace;          LogPosition logPosition = LogPosition.FileLog;          string positionParameter =  SysConfig.ToString(SysConfig.GetAppSetting("LogPath"));          SysLogger.Write(logEntry, logPosition, positionParameter);       }     }     #endregion    #region 將PPT文件轉換成HTML格式     /// <summary>     /// 將PPT文件轉換成HTML格式     /// </summary>     /// <param  name="PptFilePath">PPT文件路徑</param>     private void PptToHtmlFile(string  PptFilePath)     {        ApplicationClass ac = new ApplicationClass();        Presentation pptFile = null;       try       {          string realPath = PptFilePath.Substring(0,  PptFilePath.LastIndexOf(".")) + ".html";          PptFilePath = System.Web.HttpContext.Current.Server.MapPath(PptFilePath);          //獲得html文件名          object target = PptFilePath.Substring(0,  PptFilePath.LastIndexOf(".")) + ".html";         if (!File.Exists(target.ToString()))          {            if (PptFilePath.Contains(".pptx"))            {              pptFile = ac.Presentations.Open2007(PptFilePath, MsoTriState.msoCTrue,  MsoTriState.msoCTrue, MsoTriState.msoFalse, MsoTriState.msoFalse);              pptFile.SaveAs(target.ToString(), PpSaveAsFileType.ppSaveAsHTML,  MsoTriState.msoCTrue);            }            else if (PptFilePath.Contains(".ppt"))            {              pptFile = ac.Presentations.Open(PptFilePath, MsoTriState.msoCTrue,  MsoTriState.msoCTrue, MsoTriState.msoFalse);              pptFile.SaveAs(target.ToString(), PpSaveAsFileType.ppSaveAsHTML,  MsoTriState.msoCTrue);            }          }          //StreamReader sr = new StreamReader(target.ToString(), Encoding.Default);          //string strHtml = sr.ReadToEnd();          //Response.Write(strHtml);          HttpContext.Current.Response.Redirect(realPath);       }       finally       {          if (pptFile != null)          {            pptFile.Close();          }          ac.Quit();          GC.Collect();       }     }     #endregion   }   #endregion}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线免费视频| 国产原创欧美精品| 黄色一区二区在线观看| 日韩最新免费不卡| 久久精品国产69国产精品亚洲| 夜夜嗨av一区二区三区免费区| 亚洲欧美一区二区三区在线| 久久亚洲一区二区三区四区五区高| 亚洲欧美一区二区激情| 另类色图亚洲色图| 88xx成人精品| 精品国产乱码久久久久久婷婷| 国产精品对白刺激| 欧美在线视频播放| 国产精品第3页| 精品久久久国产精品999| 欧美激情按摩在线| 国产欧美日韩免费| 国产精品久久久久久久久借妻| 一色桃子一区二区| 九九精品视频在线观看| 国产成人91久久精品| 久久久久久亚洲精品不卡| 国语自产精品视频在线看| 亚洲欧美另类人妖| 国产精品久久久久av| 国产91精品久久久久| 亚洲成**性毛茸茸| 国产精品久久国产精品99gif| 亚洲第一网中文字幕| 久久久国产成人精品| 美女撒尿一区二区三区| 色噜噜狠狠狠综合曰曰曰88av| 欧美性猛交xxxx| 中文字幕少妇一区二区三区| 欧美精品一区二区三区国产精品| 国内精品400部情侣激情| 欧美日韩在线观看视频| 久久久女女女女999久久| 色婷婷av一区二区三区久久| 亚洲精品黄网在线观看| 国产+成+人+亚洲欧洲| 欧美视频国产精品| 色小说视频一区| 久久精品中文字幕一区| 91黑丝高跟在线| 成人黄色午夜影院| 欧美激情一区二区三区久久久| 91免费版网站入口| 亚洲国产一区二区三区四区| 国产亚洲日本欧美韩国| 日韩美女视频中文字幕| 国产成人91久久精品| 国产专区精品视频| 日韩不卡在线观看| 亚洲香蕉伊综合在人在线视看| 精品一区电影国产| 欧美日韩999| 欧美又大又粗又长| 国产精品亚洲综合天堂夜夜| 亚洲日本aⅴ片在线观看香蕉| 亚洲天堂免费观看| 亚洲精品资源美女情侣酒店| 国产精品久久久av| 91成品人片a无限观看| 亚洲成人av在线播放| 亚洲精品色婷婷福利天堂| 欧美伊久线香蕉线新在线| 中文字幕视频一区二区在线有码| 日韩精品在线第一页| 亚洲精品欧美一区二区三区| 成人两性免费视频| 精品一区二区三区四区| 亚洲黄色成人网| 午夜精品一区二区三区在线播放| 91免费在线视频| 国产一区二区三区丝袜| 国产一区二区丝袜| 国产精品欧美激情在线播放| 777精品视频| 欧美国产中文字幕| 中文日韩电影网站| 国模视频一区二区| 69影院欧美专区视频| 欧美亚洲另类视频| 欧美精品在线第一页| 久久精品夜夜夜夜夜久久| 狠狠做深爱婷婷久久综合一区| 国产在线观看不卡| 欧美日韩高清在线观看| 久久99久久久久久久噜噜| 亚洲国产欧美自拍| 国产成人精品在线| 91精品久久久久久久久久久| 日本不卡高字幕在线2019| 欧美精品激情视频| 国产精品久久久久福利| 国产精品电影久久久久电影网| 久久久久久久久久久国产| 国产丝袜一区二区三区免费视频| 91精品国产高清自在线看超| 黑人极品videos精品欧美裸| 国产成人精品999| 国产精品看片资源| 国产日韩在线观看av| 亚洲国产精品人人爽夜夜爽| 亚洲国产成人在线播放| 久久伊人精品一区二区三区| 国产精品视频免费在线| 国产美女久久精品香蕉69| 亚洲片国产一区一级在线观看| 欧美精品在线网站| 欧美日韩国产影院| 国产丝袜一区视频在线观看| 国产成人97精品免费看片| 精品久久久久久久久久久| 国产精品r级在线| 亚洲精品一区中文字幕乱码| 亚洲国产精品成人av| 欧美老肥婆性猛交视频| 亚洲精品日产aⅴ| 91tv亚洲精品香蕉国产一区7ujn| 成人春色激情网| 夜夜嗨av一区二区三区四区| 精品久久久久久久久中文字幕| 欧美日韩性视频| 欧美成人sm免费视频| 日本成人免费在线| 在线观看欧美成人| 日韩免费在线免费观看| 国产精品美女网站| 浅井舞香一区二区| 91国产美女视频| 欧美裸体男粗大视频在线观看| 久久亚洲精品小早川怜子66| 韩国三级日本三级少妇99| 亚洲国产美女久久久久| 97婷婷大伊香蕉精品视频| 中文字幕亚洲一区| 日韩成人中文字幕在线观看| **欧美日韩vr在线| 精品久久香蕉国产线看观看亚洲| 久久全国免费视频| 精品久久久一区| 91丨九色丨国产在线| 岛国av一区二区三区| 亚洲大胆人体在线| 欧美日韩国产中字| 国产精品丝袜久久久久久不卡| 日本伊人精品一区二区三区介绍| 伊是香蕉大人久久| 欧美精品久久久久a| 国产精品视频26uuu| 欧洲亚洲免费在线| 欧美电影免费观看| 久久久久久久久久久成人| 另类天堂视频在线观看| 亚洲人午夜精品免费| 中文字幕精品久久久久| 日韩黄色在线免费观看| 国产日韩中文在线| 国产精品ⅴa在线观看h| 色视频www在线播放国产成人| 欧美一级淫片播放口|