C# 操作Excel报错

错误提示:

托管调试助手 "DisconnectedContext"
  Message=托管调试助手 "DisconnectedContext":“针对此 RuntimeCallableWrapper 向 COM 上下文 0xcd9968 的转换失败,错误如下: 系统调用失败。 (异常来自 HRESULT:0x80010100 (RPC_E_SYS_CALL_FAILED))。原因通常是创建此 RuntimeCallableWrapper 的 COM 上下文 0xcd9968 已断开连接,或者该上下文正忙于执行其他操作,无法处理该上下文转换。将不会有代理服务于该 COM 组件上的请求,调用将直接转向该 COM 组件。这可能会导致损坏或数据丢失。要避免此问题,请确保在应用程序全部完成 RuntimeCallableWrapper (表示其内部的 COM 组件)之前,所有 COM 上下文/单元/线程都保持活动状态并可用于上下文转换。”

    此问题的出现时由于使用了Excel的COM,在多线程读取Excel的时候出现的,并且少量数据的时候不会出现,数据量大(测试时5000行左右)的时候才会出现,问题代码如下:

List<String[]> TaskDataList = new List<string[]>();
string[] sColumnText = new string[iColumnCount];
for (int k = 0; k < iColumnCount; k++)
{
    //问题代码
    sColumnText[k] = ((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[j, k + 1]).Text.ToString();
}
TaskDataList.Add(sColumnText);

解决办法:声明的时候将Excel相关的实例修改为 dynamic

dynamic workBook = excelApp.Workbooks.Open(PathFileName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);

dynamic workSheet = (Worksheet)workBook.Worksheets.Item[1];

以上问题是由于进程释放问题导致的,由于我在处理的时候,防止Excel进程不释放 所以增加了 进程强行杀掉的处理,因此导致的访问不到问题,在此记录一下。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值