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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 18.01.2014, 15:03
LostFuture LostFuture вне форума
Прохожий
 
Регистрация: 17.01.2014
Сообщения: 4
Версия Delphi: Delphi XE5
Репутация: 10
По умолчанию DBGrid + Access

Есть DBGrid к которому подключена база данных в формате Access, один из столбцов хранит true или false, в DBGrid это выглядит как рисованный "чекбокс" на строке.

Какое условие нужно слепить, чтобы в тех строках которые выбранные "чекбоксом" (реальное значение в таблице true) по кнопке "Save" сохранялся в тхт файл нужный столбец в строку с разделителем.

Пример:

Цитата:
Фамилия - Имя - Отчество - Дата Рождения - чекбокс
__________________________________________________ ________
Филимонов - Эдуард - Константинович - 12.05.1987 - True
Сахаров - Эдуард - Константинович - 12.05.1987 - False
Нежин - Николай - Владимирович - 15.02.1989 - True
Филимонов - Эдуард - Константинович - 12.05.1987 - False
Сахаров - Эдуард - Константинович - 12.05.1987 - True
Нежин - Николай - Владимирович - 15.02.1989 - True

В тхт выводится:
Филимонов, Нежин, Сахаров, Нежин

В StringGrid данная функция просто делалась, а в DBGrid застрял (
Спасибо.
Ответить с цитированием
  #2  
Старый 18.01.2014, 15:11
Аватар для poli-smen
poli-smen poli-smen вне форума
Профессионал
 
Регистрация: 06.08.2012
Адрес: Кривой Рог
Сообщения: 1,791
Версия Delphi: Delphi 7, XE2
Репутация: 4415
По умолчанию

Цитата:
Сообщение от LostFuture
Какое условие нужно слепить, чтобы в тех строках которые выбранные "чекбоксом" (реальное значение в таблице true) по кнопке "Save" сохранялся в тхт файл нужный столбец в строку с разделителем.
.....
В StringGrid данная функция просто делалась, а в DBGrid застрял (
Работать нужно не с DBGrid, а с тем набором данных которые отображает DBGrid, так как сам DBGrid (в отличие от StringGrid) сами данные в себе не хранит, а просто отображает те данные которые к нему "подключены".
Ответить с цитированием
  #3  
Старый 18.01.2014, 15:36
LostFuture LostFuture вне форума
Прохожий
 
Регистрация: 17.01.2014
Сообщения: 4
Версия Delphi: Delphi XE5
Репутация: 10
По умолчанию

Да это я понял, но как обратится к той же ячейке которая хранит false или true, чтобы циклом проверить их все?
Ответить с цитированием
  #4  
Старый 18.01.2014, 16:06
Аватар для poli-smen
poli-smen poli-smen вне форума
Профессионал
 
Регистрация: 06.08.2012
Адрес: Кривой Рог
Сообщения: 1,791
Версия Delphi: Delphi 7, XE2
Репутация: 4415
По умолчанию

Цитата:
Сообщение от LostFuture
Да это я понял, но как обратится к той же ячейке которая хранит false или true, чтобы циклом проверить их все?
Примерно так:
Код:
  Table1.First;
  while not Table1.Eof do
  begin
    if Table1.FieldByName('чекбокс').AsBoolean then
    begin
      WriteValue(Table1.FieldByName('Фамилия').AsString);
    end;
    Table1.Next;
  end;
Где Table1 это набор данных которые отображает DBGrid, а WriteValue функция которая дозаписывает очередное значение в нужный файл.
Ответить с цитированием
Этот пользователь сказал Спасибо poli-smen за это полезное сообщение:
LostFuture (18.01.2014)
  #5  
Старый 18.01.2014, 18:08
LostFuture LostFuture вне форума
Прохожий
 
Регистрация: 17.01.2014
Сообщения: 4
Версия Delphi: Delphi XE5
Репутация: 10
По умолчанию

Спасибо большое прибольшое.

Получилось так:
Код:
var
f: TextFile;
i, k: Integer;
s1:string;
begin
AssignFile(f,('1.txt'));
Rewrite(f);
Append(f);
DBGrid.DataSource.DataSet.First;
while not DBGrid.DataSource.DataSet.Eof do
begin
  if DBGrid.DataSource.DataSet.FieldByName('CHECK').AsBoolean then
  begin
    s1:=(DBGrid.DataSource.DataSet.FieldByName('NAME').AsString)+','+s1;
  end;
  DBGrid.DataSource.DataSet.Next;
end;
Delete(s1, Length(s1), 1);
Writeln(f,s1);
CloseFile(f);
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter