excel 异常来自 HRESULT:0x80010105 (RPC_E_SERVERFAULT)

本文探讨了在Excel中进行批量赋值时遇到的问题及解决办法。通过调整每次处理的数据行数(MAX_EVALUATE_LINES),避免了运行时错误的发生。当该参数设置过大时,可能会导致异常,适当减小其值可以有效解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

出现这种错误, 是要具体问题具体分析, 我在网上搜索发现各自的状况和解决方案都不一样.

今天在进行Excel的批量赋值的时候发现这个问题.


        
protected override void FillTableData(Excel.Range DataStartRng, System.Collections.ArrayList LeafItems, DataView dv)
        
{

            dv 
= rebuildData(dv,LeafItems);
            
//int x,y;
            
//x = dv.Count;
            
//y = LeafItems.Count;
            
//Object[,] datas = new object[x,y];
            
//for(int i=0;i<x;i++)
            
//{
            
//    for(int j=0; j<y ;j++)
            
//    {
            
//        datas[i,j] = dv[i][((RelationItem)LeafItems[j]).ColumnName];
            
//    }
            
//}

            
//Excel.Range dataRng = getRangeByRectangle(y,x,DataStartRng);
            
//dataRng.Value = datas;
            
//dataRng = null;
            Excel.Range dataRng = DataStartRng;
            
int cycleRunTimes = dv.Count / MAX_EVALUATE_LINES + (dv.Count % MAX_EVALUATE_LINES > 0 ? 1 : 0);
            
for (int i = 0; i < cycleRunTimes; i++)
            
{
                
object[,] datas =null;
                
try
                
{
                    datas 
= getSegmentData(i, dv, LeafItems);
                    dataRng 
= getRangeByRectangle(datas.GetLength(1), datas.GetLength(0), dataRng);
                }

                
catch (Exception ex)
                
{
                    
throw new Exception(string.Format("取得segment data出错,dv[..] = {0} , Error :{1}",
                        dv[i 
* MAX_EVALUATE_LINES][0],
                        ex.ToString()));
                }

                
try
                
{
                    dataRng.Value 
= datas;
                }

                
catch (Exception ex)
                
{
                    
throw new Exception(string.Format("赋值segment data出错,data[..]  = {0} ,  address :{1}, Error :{2}",
                        datas[
0,0],
                        dataRng.get_AddressLocal(
falsefalse, Excel.XlReferenceStyle.xlA1, m_objOpt, m_objOpt),
                        ex.ToString()));
                }



#if DEBUG
                    System.Diagnostics.Debug.WriteLine(String.Format(
"Lines: {0},    dataRng: {1} "
                        ,
                        i,
                        dataRng.get_AddressLocal(
falsefalse, Excel.XlReferenceStyle.xlA1, m_objOpt, m_objOpt)));
#endif
                    dataRng 
= dataRng.get_Offset(datas.GetLength(0), m_objOpt);
                

            }


        }

        
const int MAX_EVALUATE_LINES = 10;

如果我修改 MAX_EVALUATE_LINES = 100 的时候,就会时不时出现标题的错误.

减小MAX_EVALUATE_LINES 则不会出问题.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值