Worksheet get_Range throws exception

后端 未结 4 1680
一整个雨季
一整个雨季 2020-12-13 19:09

I\'m using C# to manipulate an Excel worksheet. The following two pieces of code should work the same, but one works and the other throws an exception. I wonder why.

相关标签:
4条回答
  • 2020-12-13 19:18

    Use the Worksheet Range property instead. For example, instead of

    oRange = (Excel.Range)oSheet.get_Range(oSheet.Cells[1, 1],oSheet.Cells[4,4]);
    

    use

    oRange = (Excel.Range)oSheet.Range[oSheet.Cells[1, 1],oSheet.Cells[4,4]];
    

    I was using the get_Range() method extensively when I leveraged off .NET 2. When I changed to .NET 4 Client Profile, I got this exception also. Replacing the get_Range() references with the Range property addressed this issue for me.

    0 讨论(0)
  • 2020-12-13 19:23

    I had upgraded my VS C# project from .Net Framework 3.5 to 4.5. Once I had upgraded successfully, I got this "object" does not contain a definition for 'get_Range' exception when trying to generate an excel report.

    What I did is instead of using below code

    range = xlSheet.get_Range(Cells[xlRow, xlCol], Cells[xlRow, xlCol]);
    

    I rewrote to

    range = xlSheet.Range[Cells[xlRow, xlCol], xlSheet.Cells[xlRow, xlCol]];
    

    And it worked.

    0 讨论(0)
  • 2020-12-13 19:28

    It looks like the exception is thrown from the oSheet.Cells[1, 1] and oSheet.Cells[4, 4] used as arguments to get_range.

    Applying the following, no exception will be thrown:

    Excel.Range c1 = oSheet.Cells[1, 1];
    Excel.Range c2 = oSheet.Cells[4, 4];
    oRange = (Excel.Range)oSheet.get_Range(c1, c2);
    oRange.EntireColumn.AutoFit();
    

    So, it might be related to the oSheet.get_Range functionality. It receives an object as an argument, therefore it might try to invoke a get_Range method on the arguments to receive the internal cell, and the up-cast from Range to object done by the compiler might hide the method call.

    If you need the cells definition by row/column - try using the above approach.

    0 讨论(0)
  • 2020-12-13 19:40

    For everyone who have this problem, much better use explicit conversion, rather than create new variables.

    oRange = (Excel.Range)oSheet.get_Range((Excel.Range)oSheet.Cells[1, 1], (Excel.Range)oSheet.Cells[4,4]);
    
    0 讨论(0)
提交回复
热议问题