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

Вниз

MS EXCEL 2003 + DELPHI 2007   Найти похожие ветки 

 
ganda   (2009-08-26 13:44) [0]

возникла проблема с экселем.
Работаю с экселем через модуль ComObj

oExcel := CreateOleObject("Excel.Application");
oSheet := oExcel.WorkBooks[1].Sheets[2];
oSheet.Range["A1"].select; - тут возникает ошибка метод Select  не может быть завершен верно для класса Range
пробывал заменить Select на Activate результат тот же самый.
Переустановка MS OFFICE не дала результатов! Подскажите как избавится от этого бага!
З.Ы. до сегодняшнего дня работало все


 
Ega23 ©   (2009-08-26 13:53) [1]

oSheet.Range["A1"].select

Второй параметр в Range поставить надо, вроде.


 
test ©   (2009-08-26 13:54) [2]

Если попробывать обойти траблу через макрос в Excel?

Вместо задния поведения дернуть макрос с тем же функцианалом?


 
test ©   (2009-08-26 13:58) [3]

Range["A6:AK7"].Select

Все работает. Названия Range не должны совпадать с названием ячеек


 
ganda   (2009-08-26 14:01) [4]


> Названия Range не должны совпадать с названием ячеек

как это понять?!
> Второй параметр в Range поставить надо, вроде.

что за второй параметр EmptyParam  что ли?


 
Ega23 ©   (2009-08-26 14:17) [5]


> что за второй параметр EmptyParam  что ли?


А я знаю? Я так понимаю, что Cell - это ячейка (нпример, А1). А Range - диапазон ячеек (например, с A1 по A5)
И если ты весь столбец выделить хочешь - ну запиши макрос в VBA, посмотри как это там делается, потом повтори на Delphi


 
ganda   (2009-08-26 14:24) [6]

вот собственно весь код!
в начале копирую что мне нужно
выделяю ячейку в которую мне нужно вставить то что я скопировал.

oSheet.Range["A2:K2"].copy;
oSheet.Range["A" + IntToStr(ID)].Select;
osheet.paste;

уже попробовал прописать так  
oSheet.Range["A6"].Select;
и
oSheet.Range["A6:A6"].Select; результат один и тот же


 
clickmaker ©   (2009-08-26 14:32) [7]

oSheet.Range["A6","A6"].Select


 
ganda   (2009-08-26 15:11) [8]


> oSheet.Range["A6","A6"].Select

И так не помогает!
На другой машине все отрабатывает нормально, а именно на моей не отрабатывает


 
test ©   (2009-08-26 15:24) [9]

Текст ошибки напиши


 
ganda   (2009-08-26 15:40) [10]

Метод Select из класса Range завершен неверно


 
test ©   (2009-08-27 10:36) [11]

Ты в Range можешь оперировать либо именованным блоком ячеек, либо надо задавать 2 параметра LeftTop и BottomRight для блока, ты пытаешся оперировать с помощью Range 1 ячейкой но параметры то от этого не меняются. Ты либо на Cell перейди работа с одной ячейкой, предок общий с Range многое умеет, исключения функции заточенные под блок, либо давай на вход то что ожидает функция.


 
Bless ©   (2009-08-27 11:07) [12]

Вероятно, дело здесь в том, что ты пытаешься сделать select для ячейки на странице 2,  а активна в данный момент совсем другая страница. Я не уверен, но подозреваю, что выделение (select) можно сделать только на активной странице.

Проверь: зайди в ексель, переключись в нужном документе на страницу 2 и запусти свой исходный код. Ошибка должна пропасть.


 
Bless ©   (2009-08-27 11:11) [13]

ну или перед строчкой

oSheet.Range["A1"].select;

добавь строчку
oSheet.Activate;

А тебе действительно так уж необходимы выделения ячеек при работе с excel из делфи?



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

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

Наверх




Память: 0.49 MB
Время: 0.025 c
3-1228665526
Guest
2008-12-07 18:58
2009.10.25
DBGrid по образу и подобию инспектора объектов.


2-1251403436
LSE
2009-08-28 00:03
2009.10.25
ScanLine


1-1220781512
Guest
2008-09-07 13:58
2009.10.25
Нужна помощь для связки с 1С.


2-1251817288
EH
2009-09-01 19:01
2009.10.25
Скрыть ячейки StringGrid


2-1251787851
Ruzzz
2009-09-01 10:50
2009.10.25
Посоветуйте графическую кнопку