• 操作word,Excel,PPT


    //C#编程,将Word转PDF,该方法有一定弊端,但是比起网路上的其他方法来说,还算比较好的,弊端是需要客户机上安装有WORD 2007或更高的版本。
          //1、添加引用: Microsoft.Office.Interop.Word版本12.0.0.0;
          // 2、在开头添加命名空间引用:using Microsoft.Office.Interop.Word;
          //3、具体实现方法如下:
          //Word转换成pdf
          ///<summary>
          /// 把Word文件转换成为PDF格式文件 ///</summary>
          ///<param name="sourcePath">源文件路径</param> ///<param name="targetPath">目标文件路径</param> ///<returns>true=转换成功</returns>
          public bool WordToPDF(string sourcePath, string targetPath)
          {
              //sourcePath = Server.MapPath("/Content/file/吴波.docx");
              //targetPath = Server.MapPath("/Content/file/吴波.pdf");
              bool result = false;
              WdExportFormat exportFormat = WdExportFormat.wdExportFormatPDF;
              object paramMissing = Type.Missing;
              ApplicationClass wordApplication = new ApplicationClass();
              _Document wordDocument = null;
              try
              {
                  object paramSourceDocPath = sourcePath;
                  string paramExportFilePath = targetPath;
                  WdExportFormat paramExportFormat = exportFormat;
                  bool paramOpenAfterExport = false;
                  WdExportOptimizeFor paramExportOptimizeFor = WdExportOptimizeFor.wdExportOptimizeForPrint;
                  WdExportRange paramExportRange = WdExportRange.wdExportAllDocument;
                  int paramStartPage = 0;
                  int paramEndPage = 0;
                  WdExportItem paramExportItem = WdExportItem.wdExportDocumentContent;
                  bool paramIncludeDocProps = true;
                  bool paramKeepIRM = true;
                  WdExportCreateBookmarks paramCreateBookmarks = WdExportCreateBookmarks.wdExportCreateWordBookmarks;
                  bool paramDocStructureTags = true;
                  bool paramBitmapMissingFonts = true;
                  bool paramUseISO19005_1 = false;
                  wordDocument = wordApplication.Documents.Open(
                     ref paramSourceDocPath, ref paramMissing, ref paramMissing,
                     ref paramMissing, ref paramMissing, ref paramMissing,
                    ref paramMissing, ref paramMissing, ref paramMissing,
                       ref paramMissing, ref paramMissing, ref paramMissing,
                      ref paramMissing, ref paramMissing, ref paramMissing,
                      ref paramMissing);
                  if (wordDocument != null)
                      wordDocument.ExportAsFixedFormat(paramExportFilePath,
                         paramExportFormat, paramOpenAfterExport,
                          paramExportOptimizeFor, paramExportRange, paramStartPage,
                          paramEndPage, paramExportItem, paramIncludeDocProps,
                          paramKeepIRM, paramCreateBookmarks, paramDocStructureTags,
                         paramBitmapMissingFonts, paramUseISO19005_1,
                          ref paramMissing);
                  result = true;
              }
              catch
              {
                  result = false;
              }
              finally
              {
                  if (wordDocument != null)
                  {
                      wordDocument.Close(ref paramMissing, ref paramMissing, ref paramMissing);
                      wordDocument = null;
                  }
                  if (wordApplication != null)
                  {
                      wordApplication.Quit(ref paramMissing, ref paramMissing, ref paramMissing);
                      wordApplication = null;
                  }
                  GC.Collect();
                  GC.WaitForPendingFinalizers();
                  GC.Collect();
                  GC.WaitForPendingFinalizers();
              }
              return result;
          }

          /// <summary>
          /// 把Excel文件转换成PDF格式文件 
          /// </summary>
          /// <param name="sourcePath">源文件路径</param>
          /// <param name="targetPath">目标文件路径</param>
          /// <returns>true=转换成功</returns>
          public bool XLSConvertToPDF(string sourcePath, string targetPath)
          {
              bool result = false;
              Excel.XlFixedFormatType targetType = Excel.XlFixedFormatType.xlTypePDF;
              object missing = Type.Missing;
              Excel.ApplicationClass application = null;
              Excel.Workbook workBook = null;
              try
              {
                  application = new Excel.ApplicationClass();
                  object target = targetPath;
                  object type = targetType;
                  workBook = application.Workbooks.Open(sourcePath, missing, missing, missing, missing, missing,
                      missing, missing, missing, missing, missing, missing, missing, missing, missing);
                  workBook.ExportAsFixedFormat(targetType, target, Excel.XlFixedFormatQuality.xlQualityStandard, true, false, missing, missing, missing, missing);
                  result = true;
              }
              catch
              {
                  result = false;
              }
              finally
              {
                  if (workBook != null)
                  {
                      workBook.Close(true, missing, missing);
                      workBook = null;
                  }
                  if (application != null)
                  {
                      application.Quit();
                      application = null;
                  }
                  GC.Collect();
                  GC.WaitForPendingFinalizers();
                  GC.Collect();
                  GC.WaitForPendingFinalizers();
              }
              return result;
          }
          ///<summary>       
          /// 把PowerPoint文件转换成PDF格式文件      
          ///</summary>       
          ///<param name="sourcePath">源文件路径</param>    
          ///<param name="targetPath">目标文件路径</param>
          ///<returns>true=转换成功</returns>
          public bool PPTConvertToPDF(string sourcePath, string targetPath)
          {
              bool result;
              PowerPoint.PpSaveAsFileType targetFileType = PowerPoint.PpSaveAsFileType.ppSaveAsPDF;
              object missing = Type.Missing;
              PowerPoint.ApplicationClass application = null;
              PowerPoint.Presentation persentation = null;
              try
              {
                  application = new PowerPoint.ApplicationClass();
                  persentation = application.Presentations.Open(sourcePath, MsoTriState.msoTrue, MsoTriState.msoFalse, MsoTriState.msoFalse); persentation.SaveAs(targetPath, targetFileType, Microsoft.Office.Core.MsoTriState.msoTrue);
                  result = true;
              }
              catch
              {
                  result = false;
              }
              finally
              {
                  if (persentation != null)
                  {

      //C#编程,将Word转PDF,该方法有一定弊端,但是比起网路上的其他方法来说,还算比较好的,弊端是需要客户机上安装有WORD 2007或更高的版本。 
            //1、添加引用: Microsoft.Office.Interop.Word版本12.0.0.0;
            // 2、在开头添加命名空间引用:using Microsoft.Office.Interop.Word; 
            //3、具体实现方法如下: 
            //Word转换成pdf 
            ///<summary> 
            /// 把Word文件转换成为PDF格式文件 ///</summary> 
            ///<param name="sourcePath">源文件路径</param> ///<param name="targetPath">目标文件路径</param> ///<returns>true=转换成功</returns> 
            public bool WordToPDF(string sourcePath, string targetPath)
            {
                //sourcePath = Server.MapPath("/Content/file/吴波.docx");
                //targetPath = Server.MapPath("/Content/file/吴波.pdf");
                bool result = false;
                WdExportFormat exportFormat = WdExportFormat.wdExportFormatPDF;
                object paramMissing = Type.Missing;
                ApplicationClass wordApplication = new ApplicationClass();
                _Document wordDocument = null;
                try
                {
                    object paramSourceDocPath = sourcePath;
                    string paramExportFilePath = targetPath;
                    WdExportFormat paramExportFormat = exportFormat;
                    bool paramOpenAfterExport = false;
                    WdExportOptimizeFor paramExportOptimizeFor = WdExportOptimizeFor.wdExportOptimizeForPrint;
                    WdExportRange paramExportRange = WdExportRange.wdExportAllDocument;
                    int paramStartPage = 0;
                    int paramEndPage = 0;
                    WdExportItem paramExportItem = WdExportItem.wdExportDocumentContent;
                    bool paramIncludeDocProps = true;
                    bool paramKeepIRM = true;
                    WdExportCreateBookmarks paramCreateBookmarks = WdExportCreateBookmarks.wdExportCreateWordBookmarks;
                    bool paramDocStructureTags = true;
                    bool paramBitmapMissingFonts = true;
                    bool paramUseISO19005_1 = false;
                    wordDocument = wordApplication.Documents.Open(
                       ref paramSourceDocPath, ref paramMissing, ref paramMissing,
                       ref paramMissing, ref paramMissing, ref paramMissing,
                      ref paramMissing, ref paramMissing, ref paramMissing,
                         ref paramMissing, ref paramMissing, ref paramMissing,
                        ref paramMissing, ref paramMissing, ref paramMissing,
                        ref paramMissing);
                    if (wordDocument != null)
                        wordDocument.ExportAsFixedFormat(paramExportFilePath,
                           paramExportFormat, paramOpenAfterExport,
                            paramExportOptimizeFor, paramExportRange, paramStartPage,
                            paramEndPage, paramExportItem, paramIncludeDocProps,
                            paramKeepIRM, paramCreateBookmarks, paramDocStructureTags,
                           paramBitmapMissingFonts, paramUseISO19005_1,
                            ref paramMissing);
                    result = true;
                }
                catch
                {
                    result = false;
                }
                finally
                {
                    if (wordDocument != null)
                    {
                        wordDocument.Close(ref paramMissing, ref paramMissing, ref paramMissing);
                        wordDocument = null;
                    }
                    if (wordApplication != null)
                    {
                        wordApplication.Quit(ref paramMissing, ref paramMissing, ref paramMissing);
                        wordApplication = null;
                    }
                    GC.Collect();
                    GC.WaitForPendingFinalizers();
                    GC.Collect();
                    GC.WaitForPendingFinalizers();
                }
                return result;
            }
    
    
    
            /// <summary>
            /// 把Excel文件转换成PDF格式文件  
            /// </summary>
            /// <param name="sourcePath">源文件路径</param>
            /// <param name="targetPath">目标文件路径</param>
            /// <returns>true=转换成功</returns>
            public bool XLSConvertToPDF(string sourcePath, string targetPath)
            {
                bool result = false;
                Excel.XlFixedFormatType targetType = Excel.XlFixedFormatType.xlTypePDF;
                object missing = Type.Missing;
                Excel.ApplicationClass application = null;
                Excel.Workbook workBook = null;
                try
                {
                    application = new Excel.ApplicationClass();
                    object target = targetPath;
                    object type = targetType;
                    workBook = application.Workbooks.Open(sourcePath, missing, missing, missing, missing, missing,
                        missing, missing, missing, missing, missing, missing, missing, missing, missing);
                    workBook.ExportAsFixedFormat(targetType, target, Excel.XlFixedFormatQuality.xlQualityStandard, true, false, missing, missing, missing, missing);
                    result = true;
                }
                catch
                {
                    result = false;
                }
                finally
                {
                    if (workBook != null)
                    {
                        workBook.Close(true, missing, missing);
                        workBook = null;
                    }
                    if (application != null)
                    {
                        application.Quit();
                        application = null;
                    }
                    GC.Collect();
                    GC.WaitForPendingFinalizers();
                    GC.Collect();
                    GC.WaitForPendingFinalizers();
                }
                return result;
            }
            ///<summary>        
            /// 把PowerPoint文件转换成PDF格式文件       
            ///</summary>        
            ///<param name="sourcePath">源文件路径</param>     
            ///<param name="targetPath">目标文件路径</param> 
            ///<returns>true=转换成功</returns> 
            public bool PPTConvertToPDF(string sourcePath, string targetPath)
            {
                bool result;
                PowerPoint.PpSaveAsFileType targetFileType = PowerPoint.PpSaveAsFileType.ppSaveAsPDF;
                object missing = Type.Missing;
                PowerPoint.ApplicationClass application = null;
                PowerPoint.Presentation persentation = null;
                try
                {
                    application = new PowerPoint.ApplicationClass();
                    persentation = application.Presentations.Open(sourcePath, MsoTriState.msoTrue, MsoTriState.msoFalse, MsoTriState.msoFalse); persentation.SaveAs(targetPath, targetFileType, Microsoft.Office.Core.MsoTriState.msoTrue);
                    result = true;
                }
                catch
                {
                    result = false;
                }
                finally
                {
                    if (persentation != null)
                    {
                        persentation.Close();
                        persentation = null;
                    }
                    if (application != null)
                    {
                        application.Quit();
                        application = null;
                    }
                    GC.Collect();
                    GC.WaitForPendingFinalizers();
                    GC.Collect();
                    GC.WaitForPendingFinalizers();
                }
                return result;
            }

                      persentation.Close();
                      persentation = null;
                  }
                  if (application != null)
                  {
                      application.Quit();
                      application = null;
                  }
                  GC.Collect();
                  GC.WaitForPendingFinalizers();
                  GC.Collect();
                  GC.WaitForPendingFinalizers();
              }
              return result;
          }

  • 相关阅读:
    NSURLConnection、NSURLSession
    引用自定义的framework
    iOS开发笔记
    NSFileManager文件管理
    SandBox+NSBundle
    CoreData基础
    SQLite3
    iOS中常见的设计模式——单例模式委托模式观察者模式MVC模式
    Runtime机制之结构体及操作函数
    数据结构之链表
  • 原文地址:https://www.cnblogs.com/zhaojianwei/p/4036571.html
Copyright © 2020-2023  润新知