C#將Excel轉成PDF的方法

今天小編就爲大家分享一篇關於C#將Excel轉成PDF的方法,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

PS:公司的業務中有個超級大的作業就是把OFFICE文檔轉成PDF,我猜之前沒程序猿們,公司那些人應該是一個個手動轉。強烈爲猿們感嘆,幫你們做了這麼多事,還在那抱怨....無法滿足你們的需求啊;

微軟net平臺提供了對Office文檔非常好的支持;其中有com組件直接集成到了VS中。利用這些API可以快速的免去N多繁瑣的工作;

以下代碼是翻閱了公司的代碼,一個個敲出來的;奉上代碼:

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Runtime.InteropServices;
using Microsoft.Office.Interop.Excel;
//Office 命名空間
namespace OfficeToPdf
{
  //excel 類
  class ExcelConverter
  {
    //構造函數
    public ExcelConverter()
    { }
    /// <summary>
    /// 轉換excel 成PDF文檔
    /// </summary>
    /// <param name="_lstrInputFile">原文件路徑</param>
    /// <param name="_lstrOutFile">pdf文件輸出路徑</param>
    /// <returns>true 成功</returns>
    public bool ConverterToPdf(string _lstrInputFile,string _lstrOutFile)
    {
      Microsoft.Office.Interop.Excel.Application lobjExcelApp = null;      
      Microsoft.Office.Interop.Excel.Workbooks lobjExcelWorkBooks = null;
      Microsoft.Office.Interop.Excel.Workbook lobjExcelWorkBook = null;
      string lstrTemp = string.Empty;
      object lobjMissing = System.Reflection.Missing.Value;
      try
      {
        lobjExcelApp = new Microsoft.Office.Interop.Excel.Application();
        lobjExcelApp.Visible = true;
        lobjExcelWorkBooks = lobjExcelApp.Workbooks;
        lobjExcelWorkBook = lobjExcelWorkBooks.Open(_lstrInputFile, true, true, lobjMissing, lobjMissing, lobjMissing, true,
          lobjMissing, lobjMissing, lobjMissing, lobjMissing, lobjMissing, false, lobjMissing, lobjMissing);
        //Microsoft.Office.Interop.Excel 12.0.0.0之後纔有這函數      
        lstrTemp = System.IO.Path.GetTempPath() + Guid.NewGuid().ToString() + ".xls" + (lobjExcelWorkBook.HasVBProject ? 'm' : 'x');
        //lstrTemp = System.IO.Path.GetTempPath() + Guid.NewGuid().ToString() + ".xls";
        lobjExcelWorkBook.SaveAs(lstrTemp, Microsoft.Office.Interop.Excel.XlFileFormat.xlExcel4Workbook, Type.Missing, Type.Missing, Type.Missing, false, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Type.Missing,
          false, Type.Missing, Type.Missing, Type.Missing);
        //輸出爲PDF 第一個選項指定轉出爲PDF,還可以指定爲XPS格式
        lobjExcelWorkBook.ExportAsFixedFormat(Microsoft.Office.Interop.Excel.XlFixedFormatType.xlTypePDF, _lstrOutFile, Microsoft.Office.Interop.Excel.XlFixedFormatQuality.xlQualityStandard, Type.Missing, false, Type.Missing, Type.Missing, false, Type.Missing);
        lobjExcelWorkBooks.Close();
        lobjExcelApp.Quit();
      }
      catch (Exception ex)
      {
        //其他日誌操作;
        return false;
      }
      finally {
        if (lobjExcelWorkBook != null)
        {
          lobjExcelWorkBook.Close(Type.Missing,Type.Missing,Type.Missing);
          Marshal.ReleaseComObject(lobjExcelWorkBook);
          lobjExcelWorkBook = null;
        }
        if(lobjExcelWorkBooks != null)
        {
          lobjExcelWorkBooks.Close();
          Marshal.ReleaseComObject(lobjExcelWorkBooks);
          lobjExcelWorkBooks = null;
        }
        if(lobjExcelApp != null)
        {
          lobjExcelApp.Quit();
          Marshal.ReleaseComObject(lobjExcelApp);
          lobjExcelApp = null;
        } 
        //主動激活垃圾回收器,主要是避免超大批量轉文檔時,內存佔用過多,而垃圾回收器並不是時刻都在運行!
        GC.Collect();
        GC.WaitForPendingFinalizers();
      }
      return true;
    }
  }
}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對神馬文庫的支持。如果你想了解更多相關內容請查看下面相關鏈接

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章