1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
//---------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop
#include <utilcls.h>
#include "Unit1.h" // deverou_VBE est le nom du programme
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
Variant vMSExcel;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
: TForm(Owner)
{
Variant vXLWorkbooks, vXLWorkbook, vWorksheet;
Variant vWorksheets;
vMSExcel = Variant::CreateObject("Excel.Application");
vMSExcel.OlePropertySet("Visible", true);
// ici la fenetre Excel est ouverte
// on va recuperer son Handle ainsi que celui de la barre de menus
HWND h = FindWindow("XLMAIN", "Microsoft Excel");
HWND h1 = FindWindowEx(h, NULL, "EXCEL2", NULL);
HWND h2 = FindWindowEx(h1, NULL, "MsoCommandBar", "Barre de menus Feuille de calcul");
// on selectionne la Barre de menus
SetForegroundWindow(h2);
// on active le premier element de la Barre de menus pour cela on simule "Alt"
PostMessage(h2, WM_KEYDOWN, VK_MENU, 0);
PostMessage(h2, WM_KEYUP, VK_MENU, 0);
Sleep(50);
for (int i = 1; i <= 3; i++)
{
// on simule la fleche vers le bas pour derouler le menu selectionne
PostMessage(h2, WM_KEYDOWN, VK_DOWN, 0); // touche enfoncee
PostMessage(h2, WM_KEYUP, VK_DOWN, 0); // touche relachee
}
// on simule la touche entree pour afficher la boite de dialogue
PostMessage(h2, WM_KEYDOWN, VK_RETURN, 0); // touche enfoncee
PostMessage(h2, WM_KEYUP, VK_RETURN, 0); // touche relachee
Sleep(50);
// ici la boite de dialogue ouvrir est affichee
// on recupere le Handle de la boite de dialogue
//HWND h3 = FindWindowEx(h2, NULL, "bosa_sdm_XL9", "Ouvrir");
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
// on ferme le dossier
//vXLWorkbook.OleProcedure("Close", false);
// fermeture d'excel
vMSExcel.OleFunction("Quit");
// liberation memoire
vMSExcel = Unassigned;
}
//--------------------------------------------------------------------------- |
Partager