zoukankan      html  css  js  c++  java
  • excel 异常来自 HRESULT:0x80010105 (RPC_E_SERVERFAULT)

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

    今天在进行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 则不会出问题.

  • 相关阅读:
    datatable转mode方法
    UVA10652 Board Wrapping (二维凸包+多边形面积)
    洛谷P3175 [HAOI2015]按位或 (min-max容斥 + 高维前缀和)
    icpc2020沈阳 M (fwt+高维前缀和)
    icpc2019 香港 H. Hold the Line (离线+线段树+单调队列)
    icpc2019 香港 C. Constructing Ranches (点分治)
    点分治模板
    slope trick 待填
    codeforces 713 C. Sonya and Problem Wihtout a Legend (dp(n^2)/slope trick (nlogn))
    icpc2020澳门 I. Nim Cheater (轻重链剖分优化dp空间复杂度)
  • 原文地址:https://www.cnblogs.com/king_astar/p/909411.html
Copyright © 2011-2022 走看看