欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# 如何獲取處于運行中的Excel、Word對象

 更新時間:2021年01月13日 16:27:19   作者:論眉毛你是比不過我的  
這篇文章主要介紹了C# 獲取處于運行中的Excel、Word對象操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

今日在寫項目的過程中,涉及到對Excel和Word的操作,考慮到程序的健壯性,需要對一些特殊情況作出處理,通常情況下,Excel和Word是通過winform下的openfiledialog打開的,這種情況去獲取對于對象是十分方便的。

但是有些Word或者Excel由用戶自己先行打開了,后面程序再去打開這些文檔,就會出現(xiàn)問題,這種情況需要獲取Excel或者Word對象該怎么辦呢?

通過查閱資料發(fā)現(xiàn),以下代碼可以解決。

private void OpenFileDialog()
{
  // 聲明一個對象
  Excel._Application objExcel;
  
  OpenFileDialog fileDialog = new OpenFileDialog();
  fileDialog.Multiselect = false;
  fileDialog.Title = "請選擇文件";
  
  // 此處只打開word類型文件,對過濾參數(shù)進行設置
  fileDialog.Filter = "Excel文件|*.xls;*.xlsx";
  if ( fileDialog.ShowDialog() == DialogResult.OK )
  {
    try
    {
      // 獲取到當前處于活躍狀態(tài)的Excel對象(即已經(jīng)打開的)
      objExcel = (Excel.Application)System.Runtime.InteropServices.Marshal.GetActiveObject("Excel.Application");
      // 根據(jù)選擇到的文件名去匹配工作對象
      Excel._Workbook workbook = _Excel.Workbooks.Open(fileDialog.FileName);
 
      objExcel.Visible = true;
      
    }
    catch (System.Runtime.InteropServices.COMException e)
    {
      // 假如沒有被打開,則new一個對象
      objExcel = new Excel.Application();
      // 根據(jù)選擇到的文件名去匹配工作對象
      Excel._Workbook workbook = objExcel.Workbooks.Open(fileDialog.FileName);
 
      objExcel.Visible = true;
      
    }
  } 
}

利用try catch,首先獲取處于活躍狀態(tài)的對象,獲取到Excel對象,然后用Excel文件名去匹配,獲取到工作對象。如果拋出異常,則說明目前沒有Excel被打開,于是新建一個對象來操作。

注意,此處catch里面的異常,必須要寫為"System.Runtime.InteropServices.COMException",因為如果僅僅是Exception的話,如果捕捉到其他異常,也會執(zhí)行catch里面的操作。

我們的本意是如果沒有處于活躍狀態(tài)的Excel才進行new操作,而不是任何異常都進行new對象操作。

補充:C# 獲取打開的EXCEL中某列的行數(shù)

背景

在通過C#操作EXCEL時

獲取行數(shù)

int iRowCount = worksheet.get_Range("A65535", oMissing).get_End(MExcel.XlDirection.xlUp).Row;

改為:

int iRowCount = worksheet.get_Range("A65535", "A65535").get_End(MExcel.XlDirection.xlUp).Row;

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關文章

  • C# textBox如何實時更新到最新行

    C# textBox如何實時更新到最新行

    這篇文章主要介紹了C# textBox如何實時更新到最新行問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • C#引用類型和值類型的適用場合和區(qū)別

    C#引用類型和值類型的適用場合和區(qū)別

    今天小編就為大家分享一篇關于C#引用類型和值類型的適用場合和區(qū)別,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • 基于C#實現(xiàn)的多生產(chǎn)者多消費者同步問題實例

    基于C#實現(xiàn)的多生產(chǎn)者多消費者同步問題實例

    這篇文章主要介紹了基于C#實現(xiàn)的多生產(chǎn)者多消費者同步問題,包括了加鎖與釋放鎖,以及對應臨界資源的訪問。是比較實用的技巧,需要的朋友可以參考下
    2014-09-09
  • C#Url操作類封裝、仿Node.Js中的Url模塊實例

    C#Url操作類封裝、仿Node.Js中的Url模塊實例

    這篇文章主要介紹了C#Url操作類封裝、仿Node.Js中的Url模塊,實例分析了C#Url操作類封裝的技巧,非常具有實用價值,需要的朋友可以參考下。
    2016-10-10
  • c#線程Thread示例

    c#線程Thread示例

    這篇文章主要介紹了c#線程Thread示例,需要的朋友可以參考下
    2014-05-05
  • c#語言使用Unity粒子系統(tǒng)制作手雷爆炸

    c#語言使用Unity粒子系統(tǒng)制作手雷爆炸

    這篇文章主要為大家介紹了Unity的粒子系統(tǒng)由粒子發(fā)射器、粒子動畫器、粒子渲染器組成,通過使用一或兩個紋理多次繪制,創(chuàng)造一個混沌的效果,通過復習粒子系統(tǒng)做一個手雷和實彈投擲現(xiàn)場
    2022-04-04
  • C#字符串String及字符Char的相關方法

    C#字符串String及字符Char的相關方法

    這篇文章介紹了C#字符串String及字符Char的相關方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • C#函數(shù)式編程中的惰性求值詳解

    C#函數(shù)式編程中的惰性求值詳解

    這篇文章主要介紹了C#函數(shù)式編程中的惰性求值詳解,本文講解了惰性求值的相關知識并給出代碼實例,需要的朋友可以參考下
    2015-01-01
  • c#與WMI使用技巧集

    c#與WMI使用技巧集

    c#與WMI使用技巧集...
    2007-03-03
  • C#過濾sql特殊字符串的方法

    C#過濾sql特殊字符串的方法

    這篇文章介紹了C#過濾sql特殊字符串的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07

最新評論