榪欏彧鏄竴涓皬紼嬪簭錛屽氨鏄皢ppt杞崲鎴恏tml,鏂規硶寰堝錛屼負浜嗕互鍚庡鐢紝鍦ㄦ璁板綍涓涓嬶紝涔熷拰澶у鍒嗕韓
婧愮爜濡備笅錛?br />
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(); //鍒濆鍖?/p>
//濡傛灉宸插瓨鍦紝鍒欏垹闄?br />
if (File.Exists((string)path))
{
File.Delete((string)path);
}
//鐢變簬浣跨敤鐨勬槸COM搴擄紝鍥犳鏈夎澶氬彉閲忛渶瑕佺敤Nothing浠f浛
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涓篍xcel鏂囨。鐨勪繚瀛樻牸寮?br />
PPT.PpSaveAsFileType format = PPT.PpSaveAsFileType.ppSaveAsDefault;
//灝唀xcelDoc鏂囨。瀵硅薄鐨勫唴瀹逛繚瀛樹負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 + " 鍒涘緩瀹屾瘯錛?);
}
}
}
浠ヤ笂紼嬪簭鏄嬌鐢–# 鍏堝垱寤轟竴涓猵pt 鏂囦歡騫跺悜閲岄潰鍐欏叆浜嗘枃瀛楋紝鐒跺悗鍐嶆妸姝pt 杞崲鎴恏tml ,瀵逛簬涓婇潰紼嬪簭闇瑕佽鏄庣殑鍏跺疄灝辨槸
寮曠敤dll鐨勯棶棰橈紝 鍦ㄩ」鐩腑娣誨姞寮曠敤錛屽湪com 緇勪歡涓夋嫨 microsoft powerpoint 11.0 object library 錛岃屽鏋滀綘鐨勭數鑴戞病鏈夊畨瑁?office 2003 鏄笉浼氭湁榪欎釜鐨勶紝鑰屽鏋滃畨瑁呯殑鏄痮ffice 2007 鍒欐槸microsoft powerpoint 12.0 object library銆傝屼笖鍗充嬌浣犲紩鐢ㄦ垚鍔熷悗錛岃繕鏄細緙栬瘧涓嶉氳繃錛屾槸鍥犱負灝戝畨瑁呬簡 office PIA ,鍦ㄥ畨瑁卭ffice 鏃訛紝濡傛灉浣犳槸閫夋嫨鐨勫吀鍨嬪畨瑁呮槸涓嶄細瀹夎榪欎釜鐨勶紝鍥犱負榪欎釜鍙拡瀵瑰紑鍙戜漢鍛樻墠浼氱敤鍒般傚彲浠ュ埌緗戜笂涓嬭澆涓涓?office PIA 瀹夎涓嬪氨ok浜?br />
----------------------------------Office鏂囦歡杞崲鎴怘tml鏍煎紡---------------------------------------------------------------------------------------------------------------------------------------------------------
瀵瑰簲 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鏂囦歡杞崲鎴怘tml鏍煎紡
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;background-color:#e0ecf9;margin:0px 0px 12px 0px;padding:14px 4px 12px 12px;line-height:24px;height:1%;'>浠ヤ笅鏄鏂囨。鐨凥TML棰勮鏁堟灉銆?lt;br/><span>鐢變簬鏄綉欏墊彁鍙栨樉紺簑ord涓殑鍐呭錛屾湁鍙兘閮ㄥ垎鏄劇ず涓庢簮鏂囨。涓湁宸紓錛屽鎯蟲煡鐪嬫洿鍑嗙‘鐨勪俊鎭紝</span>鎮ㄥ彲浠ョ偣鍑?amp;nbsp;<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>
/// 鎴彇瀛楃涓插乏杈規寚瀹氶暱搴?br />
/// </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 灝哤ord鏂囨。杞崲鎴怘TML鏍煎紡
/// <summary>
/// 灝哤ord鏂囨。杞崲鎴怘TML鏍煎紡
/// </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 = "---->灝哤ord鏂囨。杞崲鎴怘TML鏍煎紡寮傚父[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 灝咵xcel鏂囦歡杞崲鎴怘TML鏍煎紡
/// <summary>
/// 灝咵xcel鏂囦歡杞崲鎴怘TML鏍煎紡
/// </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("\\")) + "\\" + 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 = "---->灝咵xcel鏂囦歡杞崲鎴怘TML鏍煎紡[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 灝哖PT鏂囦歡杞崲鎴怘TML鏍煎紡
/// <summary>
/// 灝哖PT鏂囦歡杞崲鎴怘TML鏍煎紡
/// </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鏂囦歡鍚?br />
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
}
|