使用OLE获取焦点中excel工作表的ID 使用C++和OLE,我如何才能获得当前正在焦点的工作表ID?< /P>
例如,我有以下代码:使用OLE获取焦点中excel工作表的ID 使用C++和OLE,我如何才能获得当前正在焦点的工作表ID?< /P>,c++,excel,ole,worksheet,C++,Excel,Ole,Worksheet,例如,我有以下代码: Variant excelSheets; Variant excelSheet; excelSheets.OleProcedure("Add"); excelSheet= excelSheets.OlePropertyGet("Item", 1); 我想添加一张工作表,然后获取刚刚添加的工作表,以便添加内容。上述代码仅在用户不将焦点从最左侧的工作表上移开时有效 赛斯我最终使用了OlePropertyGet(“ActiveSheet”)因为
Variant excelSheets;
Variant excelSheet;
excelSheets.OleProcedure("Add");
excelSheet= excelSheets.OlePropertyGet("Item", 1);
我想添加一张工作表,然后获取刚刚添加的工作表,以便添加内容。上述代码仅在用户不将焦点从最左侧的工作表上移开时有效
赛斯我最终使用了
OlePropertyGet(“ActiveSheet”)代码>因为当你添加一个工作表时,它就变成了活动工作表,你可以从那里使用它。我在下面举了一个例子:
Variant excelApp;
Variant excelBooks;
Variant excelWorkBook;
Variant excelSheet;
Variant excelSheets;
try
{
mExcelApp = Variant::GetActiveObject("Excel.Application");
}
catch(EOleSysError& e)
{
mExcelApp = Variant::CreateObject("Excel.Application"); //open excel
}
catch(...)
{
throw;
}
mExcelApp.OlePropertySet("ScreenUpdating", true);
excelBooks = mExcelApp.OlePropertyGet("Workbooks");
excelWorkBook = excelBooks.OlePropertyGet("Item",1);
// a worksheet is added which becomes the active sheet
excelSheets.OleProcedure( "Add" );
excelSheet = excelWorkBook.OlePropertyGet( "ActiveSheet" );