Помогите, разобраться
Надо работать с несколькими книгами Excel одновременно
Вопрос первый
как перейти (сделать активным) лист с заданным номером
открыта книга workSheets и
нужно установить указатель на лист с номером i и получить объект sheet
workSheets.GetObject(sheet, prm)
как правильно сформировать и передать prm
пока получается только,если prm=_T("ActiveSheet")
Вопрос 2
Как скопировать лист из одной книги в другую
sheet - активный лист в книге 1
sheet1 - активный лист в книге 2
sheet.CallMethod(wxT("Copy")); // - копирует лист в буфер
sheet1.CallMethod(wxT("Paste")); // хотелось бы, чтобы лист скопировался перед листом sheet1 в книге 2, но... создается новая книга и туда вставляется лист из буфера
Наверняка, можно сформировать команду Copy, так чтобы указать место куда вставлять
wxAutomationObject копировать лист Excel из одной книги в другую Topic is solved
-
- In need of some credit
- Posts: 3
- Joined: Wed Feb 03, 2016 10:14 pm
-
- In need of some credit
- Posts: 3
- Joined: Wed Feb 03, 2016 10:14 pm
Re: wxAutomationObject копировать лист Excel из одной книги в другую
Первый вопрос отпал, вот пример, как по номеру листа получить объект - Лист, потом взять его имя
....
....
Code: Select all
listCount - число листов в книге
for (int i=1;i<=listCount;i++) // перебор листов
{ wxString strI; // строка для формирования номера листа
wxVariant avSheetsItem[1]; // один параметр для формирования номера листа
strI <<i; // преобразование числа в строку
avSheetsItem[0] = wxVariant(strI); // формирование параметра с номером листа ( преобразование строки в wxVariant )
workSheets.GetObject(sheet , wxT("Item"), 1, avSheetsItem); //sheet - объект - Item[i]
// взять имя листа
wxString nameSheet1;
wxVariant Vname1;
Vname1=sheet.GetProperty(wxT("Name")); // взять имя листа для объекта sheet
nameSheet1=Vname1.GetString(); // получить имя в виде строки
wxMessageBox(nameSheet1);
}
-
- In need of some credit
- Posts: 3
- Joined: Wed Feb 03, 2016 10:14 pm
Re: wxAutomationObject копировать лист Excel из одной книги в другую
Сама разобралась, правда, не совсем так, как хотелось.
Не получилось применить команду Соpy с параметрами. Выкрутилась по другому.
Чтобы скопировать лист из одной книги в другую в заданное место, надо выделить все ячейки на первом листе, затем выделить лист перед которым будет вставлен лист, добавить новый лист и вставить в него, то что в буфере
Полностью файл oleauto.cpp с окошком и меню, в который добавлен функционал копирования листов
Не получилось применить команду Соpy с параметрами. Выкрутилась по другому.
Чтобы скопировать лист из одной книги в другую в заданное место, надо выделить все ячейки на первом листе, затем выделить лист перед которым будет вставлен лист, добавить новый лист и вставить в него, то что в буфере
Code: Select all
// получить последний лист во второй книге
wxVariant avSheets1Item[1];
avSheets1Item[0] =wxVariant(listCount1);
workSheets1.GetObject(sheet1 , wxT("Item"), 1, avSheets1Item);
// получить и вывести имя листа
Vname2=sheet1.GetProperty(wxT("Name"));
nameSheet2=Vname2.GetString();
wxMessageBox(nameSheet2);
//________________________
//Копирование содержимого из одного листа в другой
sheet.GetObject(cells, wxT("Cells"));
cells.CallMethod(wxT("Copy"));
sheet1.CallMethod(wxT("Select"));
workSheets1.CallMethod(wxT("Add"));
excelObject.GetObject(sheet1,_T("ActiveSheet"));
sheet1.CallMethod(wxT("Select"));
//______________вставка из буфера на выделенный лист_______________
sheet1.CallMethod(_("Paste"));
Code: Select all
/////////////////////////////////////////////////////////////////////////////
// Name: oleauto.cpp
// Purpose: OLE Automation wxWidgets sample
// Author: Julian Smart
// Modified by:
// Created: 08/12/98
// RCS-ID: $Id: oleauto.cpp 40587 2006-08-13 01:17:53Z VZ $
// Copyright: (c) Julian Smart
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
//______________________________________________________________________________________________
// |
// |
// Добавлено в пример 2016-02-6 копирование листа из одной книги xl в другую |
// Работа с листами по номеру, изменение имени листа |
// Добавление листа в книгу перед указанным листом |
// файлы должны существовать в заданном месте, в программе не проверяется наличие файлов |
// |
// копируется лист из файла d:\\f.xls в файл d:\\ff.xls перед последним листом |
// |
//______________________________________________________________________________________________|
// ============================================================================
// declarations
// ============================================================================
// ----------------------------------------------------------------------------
// headers
// ----------------------------------------------------------------------------
// For compilers that support precompilation, includes "wx/wx.h".
#include "wx/wxprec.h"
#ifdef __BORLANDC__
#pragma hdrstop
#endif
// for all others, include the necessary headers (this file is usually all you
// need because it includes almost all "standard" wxWidgets headers
#ifndef WX_PRECOMP
#include "wx/wx.h"
#endif
#include "wx/msw/ole/automtn.h"
#ifndef __WXMSW__
#error "Sorry, this sample works under Windows only."
#endif
// ----------------------------------------------------------------------------
// ressources
// ----------------------------------------------------------------------------
// the application icon
#if defined(__WXGTK__) || defined(__WXX11__) || defined(__WXMOTIF__)
#include "mondrian.xpm"
#endif
// ----------------------------------------------------------------------------
// private classes
// ----------------------------------------------------------------------------
// Define a new application type, each program should derive a class from wxApp
class MyApp : public wxApp
{
public:
// override base class virtuals
// ----------------------------
// this one is called on application startup and is a good place for the app
// initialization (doing it here and not in the ctor allows to have an error
// return: if OnInit() returns false, the application terminates)
virtual bool OnInit();
};
// Define a new frame type: this is going to be our main frame
class MyFrame : public wxFrame
{
public:
// ctor(s)
MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size);
// event handlers (these functions should _not_ be virtual)
void OnQuit(wxCommandEvent& event);
void OnAbout(wxCommandEvent& event);
void OnTest(wxCommandEvent& event);
private:
// any class wishing to process wxWidgets events must use this macro
DECLARE_EVENT_TABLE()
};
// ----------------------------------------------------------------------------
// constants
// ----------------------------------------------------------------------------
// IDs for the controls and the menu commands
enum
{
// menu items
OleAuto_Quit = 1,
OleAuto_About,
OleAuto_Test,
// controls start here (the numbers are, of course, arbitrary)
OleAuto_Text = 1000
};
// ----------------------------------------------------------------------------
// event tables and other macros for wxWidgets
// ----------------------------------------------------------------------------
// the event tables connect the wxWidgets events with the functions (event
// handlers) which process them. It can be also done at run-time, but for the
// simple menu events like this the static method is much simpler.
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
EVT_MENU(OleAuto_Quit, MyFrame::OnQuit)
EVT_MENU(OleAuto_About, MyFrame::OnAbout)
EVT_MENU(OleAuto_Test, MyFrame::OnTest)
END_EVENT_TABLE()
// Create a new application object: this macro will allow wxWidgets to create
// the application object during program execution (it's better than using a
// static object for many reasons) and also declares the accessor function
// wxGetApp() which will return the reference of the right type (i.e. MyApp and
// not wxApp)
IMPLEMENT_APP(MyApp)
// ============================================================================
// implementation
// ============================================================================
// ----------------------------------------------------------------------------
// the application class
// ----------------------------------------------------------------------------
// `Main program' equivalent: the program execution "starts" here
bool MyApp::OnInit()
{
// Create the main application window
MyFrame *frame = new MyFrame(_T("OleAuto wxWidgets App"),
wxPoint(50, 50), wxSize(450, 340));
// Show it and tell the application that it's our main window
// @@@ what does it do exactly, in fact? is it necessary here?
frame->Show(true);
SetTopWindow(frame);
// success: wxApp::OnRun() will be called which will enter the main message
// loop and the application will run. If we returned false here, the
// application would exit immediately.
return true;
}
// ----------------------------------------------------------------------------
// main frame
// ----------------------------------------------------------------------------
// frame constructor
MyFrame::MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size)
: wxFrame((wxFrame *)NULL, wxID_ANY, title, pos, size)
{
// set the frame icon
SetIcon(wxICON(mondrian));
// create a menu bar
wxMenu *menuFile = new wxMenu;
menuFile->Append(OleAuto_Test, _T("&Test Excel Automation..."));
menuFile->Append(OleAuto_About, _T("&About..."));
menuFile->AppendSeparator();
menuFile->Append(OleAuto_Quit, _T("E&xit"));
// now append the freshly created menu to the menu bar...
wxMenuBar *menuBar = new wxMenuBar;
menuBar->Append(menuFile, _T("&File"));
// ... and attach this menu bar to the frame
SetMenuBar(menuBar);
#if wxUSE_STATUSBAR
// create a status bar just for fun (by default with 1 pane only)
CreateStatusBar(2);
SetStatusText(_T("Welcome to wxWidgets!"));
#endif // wxUSE_STATUSBAR
}
// event handlers
void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
{
// true is to force the frame to close
Close(true);
}
void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
{
wxMessageBox(_T("This is an OLE Automation sample"),
_T("About OleAuto"), wxOK | wxICON_INFORMATION, this);
}
/* Tests OLE automation by making the active Excel cell bold,
* and changing the text.
*/
void MyFrame::OnTest(wxCommandEvent& WXUNUSED(event))
{ // файлы должны сущществовать в заданном месте, в программе не проверяется наличие файлов
// копируется лист из файла d:\\f.xls в файл d:\\ff.xls перед последним листом
wxString strFileName;
wxString strFileName1;
strFileName<<"d:\\f.xls";
strFileName1<<"d:\\ff.xls";
wxMessageBox(_T("Please ensure Excel is running, then press OK.\nThe active cell should then say 'wxWidgets automation test!' in bold."));
wxAutomationObject excelObject, rangeObject, chartObject,
workBooks, workBook, workSheets, sheet,cells, cell, m_Grid,
workBook1, workSheets1, sheet1;
if (!excelObject.GetInstance(_T("Excel.Application")))
{
if (!excelObject.CreateInstance(_T("Excel.Application")))
{
wxMessageBox(_T("Could not create Excel object."));
return;
}
}
// excelObject.PutProperty(wxT("Visible"), true);
//открыть книгу 1__________________________________________________________
wxVariant prm[1];
prm[0]=wxVariant(strFileName);
wxVariant ret=excelObject.CallMethod(wxT("Workbooks.Open"),strFileName);
excelObject.GetObject(workBook, wxT("ActiveWorkbook"));
workBook.GetObject(workSheets, wxT("Worksheets"));
long listCount=0;
listCount=workSheets.GetProperty(wxT("Count"));
wxString msgC;
msgC <<"число листов в книге "<<listCount;
wxMessageBox(msgC);
//ПЕРЕбор листов в первой книге и вывод имен
{wxString spNameSheets;
for (int i=1;i<=listCount;i++)
{// формирование параметра с номером листа
wxString strI;
wxVariant avSheetsItem[1];
strI<<i;
avSheetsItem[0] =wxVariant(i);
// получить лист с заданным номером
workSheets.GetObject(sheet , wxT("Item"), 1, avSheetsItem);
// взять имя листа
wxString nameSheet1;
wxVariant Vname1;
Vname1=sheet.GetProperty(wxT("Name"));
nameSheet1=Vname1.GetString();
spNameSheets<<" Лист "<<strI<<" имя = _"<<nameSheet1<<"_; ";
//wxMessageBox(spNameSheets);
wxMessageBox(nameSheet1);
}
wxMessageBox(spNameSheets);
}
//Открыть вторую книгу__________________________________________________________
wxVariant ret1=excelObject.CallMethod(wxT("Workbooks.Open"),strFileName1);
excelObject.GetObject(workBook1, wxT("ActiveWorkbook"));
workBook1.GetObject(workSheets1, wxT("Worksheets"));
long listCount1=0;
listCount1=workSheets1.GetProperty(wxT("Count"));
msgC="";
msgC <<"число листов в книге2 ="<<listCount1;
wxMessageBox(msgC);
wxString nameSheet2;
wxVariant Vname2;
// получить последний лист во второй книге
wxVariant avSheets1Item[1];
avSheets1Item[0] =wxVariant(listCount1);
workSheets1.GetObject(sheet1 , wxT("Item"), 1, avSheets1Item);
// получить и вывести имя листа
Vname2=sheet1.GetProperty(wxT("Name"));
nameSheet2=Vname2.GetString();
wxMessageBox(nameSheet2);
//________________________
//Копирование содержимого из одного листа в другой
sheet.GetObject(cells, wxT("Cells"));
cells.CallMethod(wxT("Copy"));
sheet1.CallMethod(wxT("Select"));
workSheets1.CallMethod(wxT("Add"));
excelObject.GetObject(sheet1,_T("ActiveSheet"));
sheet1.CallMethod(wxT("Select"));
//______________вставка из буфера на выделенный лист_______________
sheet1.CallMethod(_("Paste"));
//_______________________________________________________________________________________
excelObject.GetObject(sheet1,_T("ActiveSheet"));
wxString nameSheet;
wxVariant Vname;
Vname=sheet1.GetProperty(wxT("Name"));
nameSheet=Vname.GetString();
wxMessageBox(nameSheet);
nameSheet<<listCount1;
//переименовать лист
sheet1.PutProperty(wxT("Name"),nameSheet);
//_____сохранить обе книги и закрыть ____Excel________________________________________________________________________
wxMessageBox(_("Закрытие Excel"));
workBook.CallMethod(wxT("Save"));
workBook.CallMethod(wxT("Close"));
workBook1.CallMethod(wxT("Save"));
workBook1.CallMethod(wxT("Close"));
excelObject.CallMethod(wxT("Quit"));
return;
//
}