Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.07.18;
Скачать: CL | DM;

Вниз

Как объединить две ячейки в Excel программно?   Найти похожие ветки 

 
cardinall   (2004-06-17 08:49) [0]

Есть шаблон Excel.xlt. Мне необходимо програмно некоторые ячейки в ходе генерирования отчета объединять.


 
Ozone ©   (2004-06-17 08:51) [1]

Пиши макрос и делай по аналогии


 
YurikGL ©   (2004-06-17 08:59) [2]

что-то вроде Excelapplication1.range("a1","d1").merge(nil);


 
User_Name   (2004-06-17 09:59) [3]

Я пользуюсь такой функцией

function SetRange(WorkBook: OleVariant; y1, x1, y2, x2: Integer): OleVariant;
begin
Result := WorkBook.WorkSheets[1].Range[
  WorkBook.WorkSheets[1].Cells[y1, x1],
  WorkBook.WorkSheets[1].Cells[y2, x2]];
end;

© не мой :)


 
cardinall   (2004-06-18 16:30) [4]

Вобщем такой вариант работает. Все подробно... В цикле объеденяем ячейки, которые необходимо объединить.

uses  ExcelXP,ActiveX,ComObj;
...
type
IxlApplication = ExcelXP._Application;
IxlWorkbook = ExcelXP._Workbook;
IxlWorksheet = ExcelXP._Worksheet;
IxlRange = ExcelXP.ExcelRange;
...
var
FIXLSApp: IxlApplication;
FLCID: LCID;
...
procedure MergeCells;
var
IWorkbook: IxlWorkbook;
ISheet: IxlWorksheet;
StartROW: Integer;
IR1, IR2: IxlRange;
COUNT:    Integer;
begin
StartROW := 12;
COUNT := 0;
IWorkbook := FIXLSApp.Workbooks.Add(ExpandFileName("TEMPLATE\Template1.xlt"), FLCID);
ISheet := IWorkbook.Worksheets.Item["Sheet1"] as ExcelXP._Worksheet;
SomeTable.First;
while not SomeTable.EOF do
 begin
  //--------------------------------------------------
  IDispatch(IR1) := ISheet.Cells.Item[StartROW+COUNT, 2];
  IDispatch(IR2) := ISheet.Cells.Item[StartROW+COUNT, 3];
  ISheet.Range[IR1,IR2].Merge(0);
  INC(COUNT);
  //--------------------------------------------------
  SomeTable.Next;
 end;
end;


 
Romkin ©   (2004-06-18 16:37) [5]

Только merge(EmptyParam) или Merge(False) - просто точнее :)



Страницы: 1 вся ветка

Текущий архив: 2004.07.18;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.022 c
1-1088532999
Studentik
2004-06-29 22:16
2004.07.18
Компоненты не влезают на форму под XP


6-1085385125
Vik_Sennikov
2004-05-24 11:52
2004.07.18
Сохранение картинки средствами IE


14-1088567524
alexa
2004-06-30 07:52
2004.07.18
Установка Delphi.net


14-1088422144
Rem
2004-06-28 15:29
2004.07.18
Парадокс


3-1087982537
чайник1
2004-06-23 13:22
2004.07.18
Фильтр по симв.полю