Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Технологии
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 04.02.2009, 23:35
Аватар для Dux
Dux Dux вне форума
Активный
 
Регистрация: 18.03.2008
Сообщения: 206
Репутация: 16
По умолчанию Как удалить все строки в Excel содержащие..

Столкнулся с проблемой, необходимо из Дельфи удалить все строки в Excel таблице, в которых в первом столбце содержится символ "х"? Помогите советом

Пробую так, но видать где-то ошибка:

Код:
 for I2 := 0 to 200 do
   begin
    if XL.Cells[I2,1].value='x' then  begin XL.Rows[i2].delete;end;
   end;
Ответить с цитированием
  #2  
Старый 05.02.2009, 01:33
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,004
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

А в чем ошибка проявляется?
Ответить с цитированием
  #3  
Старый 05.02.2009, 23:30
Аватар для Dux
Dux Dux вне форума
Активный
 
Регистрация: 18.03.2008
Сообщения: 206
Репутация: 16
По умолчанию

Цитата:
Сообщение от lmikle
А в чем ошибка проявляется?

Если в двух строках подряд имеется символ "х" удаляется только одна..
Ответить с цитированием
  #4  
Старый 06.02.2009, 06:40
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Это потому, что когда ты удаляешь строку в экселе, то автоматически меняется адресация (попробуй ручками удалить строку). Чтобы обойти эту фичу делай просто - двигайся снизу вверх по строчкам, и цикл используй не for, а while или repeat.
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #5  
Старый 06.02.2009, 22:46
Аватар для Dux
Dux Dux вне форума
Активный
 
Регистрация: 18.03.2008
Сообщения: 206
Репутация: 16
По умолчанию

Спасибо за идею... все заработало. Единственный вопрос остался, как посчитать количество заполненных строк на листе чтобы правильно организовать цикл. Подскажите...
Ответить с цитированием
  #6  
Старый 07.02.2009, 04:41
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Вот код на VBA, под Delphi сам адаптируй
Код:
    iAddress = Range("A1").SpecialCells(xlLastCell).Address
    irow = Range("A1").SpecialCells(xlLastCell).Row
    iclm = Range("A1").SpecialCells(xlLastCell).Column
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #7  
Старый 14.02.2009, 00:23
erazer erazer вне форума
Прохожий
 
Регистрация: 14.02.2009
Сообщения: 1
Репутация: 10
По умолчанию

Ребята, помогите пожалуйста!! Буду благодарен за VBA код для удаления строк, в которых в 13-ом столбце содержится значение "3". Очень надо.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 11:28.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter