Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как записать содежимое DBGrid в текстовый файл 
:(
    Опции темы
AstalaVista
Дата 25.4.2005, 20:20 (ссылка)    |    (голосов: 0) Загрузка ... Загрузка ... Быстрая цитата Цитата


Unregistered











Подскажите плиз как записать в файл txt все, что есть в данный момент в DBGrid.

  Вверх
Alex
Дата 26.4.2005, 00:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Экс. модератор
Сообщений: 4147
Регистрация: 25.3.2002
Где: Москва

Репутация: 17
Всего: 162



Код

function DBGridToCsv(Grid: TDBGrid; aFile: String): Boolean;
var
  i, cnt: Integer;
  rLst: TStringList;
begin
  Result:= False;
  if (aFile = ''                           ) or
     (not Assigned(Grid)                   ) or
     (not Assigned(Grid.DataSource)        ) or
     (not Assigned(Grid.DataSource.DataSet)) or
     (not Grid.DataSource.DataSet.Active   ) then Exit;

  rLst:= TStringList.Create;
  try
    with Grid do try
      DataSource.DataSet.DisableControls;
      cnt:= FieldCount-1; // для ускорения алгоритма
      // Запомним название колонок
      with TStringList.Create do try
        Delimiter:= ';';
        for i:= 0 to cnt do Add(Columns[i].Title.Caption);
        rLst.Add(DelimitedText);
      finally
        Free;
      end;
      // Запоминаем содержимое колонок
      while not DataSource.DataSet.Eof do begin
        with TStringList.Create do try
          Delimiter:= ';';
          for i:= 0 to cnt do Add(Fields[i].AsString);
          rLst.Add(DelimitedText);
        finally
          Free;
        end;
        DataSource.DataSet.Next;
      end;
      rLst.SaveToFile(aFile); // Сохраняем результат
    finally
      DataSource.DataSet.EnableControls;
    end;
  finally
    rLst.Free;
  end;
  Result:= True;
end;



--------------------
Написать можно все - главное четко представлять, что ты хочешь получить в конце. 
PM Skype   Вверх
AstalaVista
Дата 26.4.2005, 12:39 (ссылка)    |    (голосов: 0) Загрузка ... Загрузка ... Быстрая цитата Цитата


Unregistered











Спасибо smile
  Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0956 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.