Главная страница
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.018 c
15-1250967890
@!!ex
2009-08-22 23:04
2009.10.25
Linux -это всегда OpenSource?


15-1251232204
Юрий
2009-08-26 00:30
2009.10.25
С днем рождения ! 26 августа 2009 среда


2-1251794492
sanx
2009-09-01 12:41
2009.10.25
Как вызвать звук который издает, при клике, окно под модальным?


2-1251913566
Shyrick
2009-09-02 21:46
2009.10.25
SQL-запрос


4-1220124773
yaric
2008-08-30 23:32
2009.10.25
Путь к файлу в котром присутствует кириллица