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

Вниз

Excel   Найти похожие ветки 

 
StarCon   (2003-04-02 13:55) [0]

Здравствуйте!
нужно пройтись в цикле по строкам экселевского листа
делаю так:
for r := 1 to XL.WorkBooks[1].WorkSheets[i].Cells.Rows.Count do
begin
if VartoStr(XL.WorkBooks[1].WorkSheets[i].Cells[r, 2]) <> ""
then RichEdit.Lines.Add(InttoStr(r) + " - " +
VartoStr(XL.WorkBooks[1].WorkSheets[i].Cells[r, 2]));
end;
но перебрать 65500 строк в экселе довольно долго
есль ли способ задать в цикл только задействованную область строк?


 
Smashich ©   (2003-04-02 13:58) [1]

Range?


 
StarCon   (2003-04-02 14:12) [2]

да хоть Range хоть просто Cells
проблема в том что изначально не известно 1 строка 50 или еще сколько... а перебирать приходиться все, сколько в экселе существует по умолчанию


 
Наталия ©   (2003-04-02 14:14) [3]

UsedRange посмотри


 
StarCon   (2003-04-02 14:21) [4]

негде посмотреть...
примерчик бы....


 
StarCon   (2003-04-02 14:22) [5]

спасибо!
нашел в поисковике


 
NickBat ©   (2003-04-02 14:24) [6]

А если так:

var
ISheet: Excel2000._Worksheet;
IRange: Excel2000.Range;

begin
ISheet:=Workbook.Worksheets.Item["Лист1"] as Excel2000._Worksheet;
IRange := ISheet.UsedRange[xlLCID];
for ii:=1 to IRange.Rows.Count do
tmp:=IRange.Item[ii,1].Value;




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

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

Наверх




Память: 0.47 MB
Время: 0.013 c
1-44130
mazepa
2003-04-03 09:18
2003.04.14
Line


14-44428
kostya2000
2003-03-28 23:20
2003.04.14
Что будет если nVidia Riva TNT 2 скрестить с Voodoo 2?


6-44302
valerchik
2003-02-20 21:51
2003.04.14
подсчет трафика...


3-44064
Kremen
2003-03-24 17:30
2003.04.14
Раскраска Cells в dbgrid


14-44397
SV
2003-03-25 21:03
2003.04.14
NET Project