Excel COM Object Cast Error

Опитвам се да избегна означение "двойна точка" в кода си (вижте Как да изчистя правилно обектите за взаимодействие на Excel?). Получавам обаче грешка, когато се опитам да променя следния код

Excel.Workbook oWB;
...
oWB.Sheets[oWB.Sheets.Count].Delete();
oWB.Sheets[oWB.Sheets.Count].Delete();
oWB.Sheets[oWB.Sheets.Count].Delete();

до това

Excel.Sheets oS;
oS = oWB.Sheets;
//error occurs in the following line
oS = oWB.Sheets[oS.Count];
oS.Delete();
oS.Delete();
os.Delete();

Грешката е 'Unable to cast COM object of type 'System.__ComObject' to interface type 'Microsoft.Office.Interop.Excel.Sheets'. This operation failed because the QueryInterface call on the COM component for the interface with IID '{000208D7-0000-0000-C000-000000000046}' failed due to the following error: No such interface supported (Exception from HRESULT: 0x80004002 (E_NOINTERFACE)).'

Всяка помощ се оценява.


person kaoao    schedule 29.09.2014    source източник


Отговори (1)


Трябва да декларирате нова променлива от тип Sheet. oS е от тип Sheets, докато oS.Sheets[os.Count] е от тип Sheet (без крайни 's'). Тъй като те са несвързан тип от гледна точка на времето за изпълнение, трябва да декларирате междинна променлива с подходящ тип Sheet.

person Seb    schedule 29.09.2014
comment
Благодаря за обратната връзка - person Seb; 29.09.2014