服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - C# 如何获取处于运行中的Excel、Word对象

C# 如何获取处于运行中的Excel、Word对象

2022-10-27 13:21论眉毛你是比不过我的 C#

这篇文章主要介绍了C# 获取处于运行中的Excel、Word对象操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

今日在写项目的过程中,涉及到对Excel和Word的操作,考虑到程序的健壮性,需要对一些特殊情况作出处理,通常情况下,Excel和Word是通过winform下的openfiledialog打开的,这种情况去获取对于对象是十分方便的。

但是有些Word或者Excel由用户自己先行打开了,后面程序再去打开这些文档,就会出现问题,这种情况需要获取Excel或者Word对象该怎么办呢?

通过查阅资料发现,以下代码可以解决。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
private void OpenFileDialog()
{
  // 声明一个对象
  Excel._Application objExcel;
  
  OpenFileDialog fileDialog = new OpenFileDialog();
  fileDialog.Multiselect = false;
  fileDialog.Title = "请选择文件";
  
  // 此处只打开word类型文件,对过滤参数进行设置
  fileDialog.Filter = "Excel文件|*.xls;*.xlsx";
  if ( fileDialog.ShowDialog() == DialogResult.OK )
  {
    try
    {
      // 获取到当前处于活跃状态的Excel对象(即已经打开的)
      objExcel = (Excel.Application)System.Runtime.InteropServices.Marshal.GetActiveObject("Excel.Application");
      // 根据选择到的文件名去匹配工作对象
      Excel._Workbook workbook = _Excel.Workbooks.Open(fileDialog.FileName);
 
      objExcel.Visible = true;
      
    }
    catch (System.Runtime.InteropServices.COMException e)
    {
      // 假如没有被打开,则new一个对象
      objExcel = new Excel.Application();
      // 根据选择到的文件名去匹配工作对象
      Excel._Workbook workbook = objExcel.Workbooks.Open(fileDialog.FileName);
 
      objExcel.Visible = true;
      
    }
  }
}

利用try catch,首先获取处于活跃状态的对象,获取到Excel对象,然后用Excel文件名去匹配,获取到工作对象。如果抛出异常,则说明目前没有Excel被打开,于是新建一个对象来操作。

注意,此处catch里面的异常,必须要写为"System.Runtime.InteropServices.COMException",因为如果仅仅是Exception的话,如果捕捉到其他异常,也会执行catch里面的操作。

我们的本意是如果没有处于活跃状态的Excel才进行new操作,而不是任何异常都进行new对象操作。

补充:C# 获取打开的EXCEL中某列的行数

背景

在通过C#操作EXCEL时

获取行数

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

改为:

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。

原文链接:https://blog.csdn.net/Ck_Max/article/details/99953873

延伸 · 阅读

精彩推荐
  • C#C#文件目录操作方法汇总

    C#文件目录操作方法汇总

    本文主要列举出C#文件和目录操作的一些方法,包括创建、移动、遍历目录,读写文件等方法,有需要的小伙伴可以学习一下。...

    jerrylsxu7922021-11-19
  • C#C#中类成员的定义的修饰关键词知识点总结

    C#中类成员的定义的修饰关键词知识点总结

    在本篇文章里小编给大家整理了关于C#中类成员的定义的修饰关键词知识点内容,有需要的朋友们可以参考下。...

    Hercules_Chung8522022-08-24
  • C#c# 播放声音的四种方法

    c# 播放声音的四种方法

    这篇文章主要介绍了c# 播放声音的四种方法,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下...

    搜源网10412022-10-18
  • C#c# 通过WinAPI播放PCM声音

    c# 通过WinAPI播放PCM声音

    这篇文章主要介绍了c# 通过WinAPI播放PCM声音的方法,帮助大家更好的理解和使用c#编程语言,感兴趣的朋友可以了解下...

    天方11462022-10-21
  • C#C#中Json反序列化的实现方法

    C#中Json反序列化的实现方法

    这篇文章主要给大家介绍了关于C#中Json反序列化的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    刘Te10972022-02-24
  • C#WPF实现魔方小游戏

    WPF实现魔方小游戏

    这篇文章主要为大家详细介绍了WPF实现魔方小游戏,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    mq_shouhug753951mq10122022-02-20
  • C#c# 实现子窗口关闭父窗口也关闭的简单实例

    c# 实现子窗口关闭父窗口也关闭的简单实例

    下面小编就为大家带来一篇c# 实现子窗口关闭父窗口也关闭的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看...

    C#教程网6512021-12-27
  • C#C# 获取某个时间的0点0分和23点59分59秒

    C# 获取某个时间的0点0分和23点59分59秒

    这篇文章主要介绍了C# 获取某个时间的0点0分和23点59分59秒,文中给大家提到了java 获取某一日期的0点0分0秒和23点59分59秒,需要的朋友可以参考下...

    derr8962022-08-05