0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 33
Delphi 6-7

Перенос отфильтрованных строк из DBGrid в Exel

09.04.2019, 13:48. Показов 1481. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Делаю фильтр по таблице.

Delphi
1
2
form2.AdsTable1.Filter:='IZGOT2='+chr(39)+trim(form2.Combobox1.Text +' '+  Form2.Combobox2.Text)+chr(39);
             form2.AdsTable1.Filtered:=true;
После этого фильтра хочу вывести отфильтрованные строки в Exel:

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
var
ExcelApp : variant;
row :integer;
col:integer;
begin
form2.DBGRID1.DataSource.DataSet.First;
ExcelApp:=CreateOleObject('Excel.Application');
ExcelApp.workbooks.open(ExtractFilePath(ParamStr(0))+'reestr.xls');
ExcelApp.Visible := false;
for row := 0 to form2.DBGrid1.DataSource.DataSet.RecordCount-1 do
begin
for col := 0 to form2.DBGrid1.Columns.Count-1 do
 
ExcelApp.WorkBooks[1].WorkSheets[1].cells[row+4,col+2].value:=form2.DBgrid1.DataSource.DataSet.Fields[col].AsString;
ExcelApp.WorkBooks[1].WorkSheets[1].cells[row+4,1]:=row+1;
end;
 
form2.Dbgrid1.DataSource.DataSet.Next;
ExcelApp.Visible := True;
end;
end;

Если в базе данных 5 строк и из них я фильтром нахожу 1, то и в эксель должна 1 выводиться, но выводится 5.
Что не так?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.04.2019, 13:48
Ответы с готовыми решениями:

Перенос строк из DBGRID в EXEL
Может кто подскажет в чем может быть проблема, при переносе, например 3 строк из dbgrid в эксель, в экселе отображается 3 строки но все...

Перенос нескольких строк DbGrid
У меня есть 2 DBGrida , задача: Я выделяю несколько строк в 1Гриде и надо перенести во второй, только все выделенные значения должны...

Из DBGrid в Exel
Добрый день. Подскажите пожалуйста как решить вот такую проблему. Имеется бд акссес. К ней у меня установлено подключение через делфи. ...

7
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
09.04.2019, 14:02
скорее всего записи не фильтруются. выложите проект сюда, посмотрим
0
0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 33
09.04.2019, 14:06  [ТС]
Вот код
Вложения
Тип файла: rar 1.rar (477.4 Кб, 8 просмотров)
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
09.04.2019, 14:20
у Вас установлены сторонние компоненты, поэтому мне не удалось скомпилировать проект
0
0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 33
09.04.2019, 14:22  [ТС]
может подскажете как предварительно поставить фильтр на таблицу?
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
09.04.2019, 14:32
давайте попробуем "в лоб", т.е. вот так
Delphi
1
2
3
4
5
with form2.AdsTable1 do begin
  Filtered:=False;   
  Filter:='IZGOT2='+chr(39)+'март 2023'+chr(39);
  Filtered:=True;
end;
0
0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 33
09.04.2019, 14:39  [ТС]
может не так выразился, в DbGrid выводится все хорошо, но в эксель одна и та же строка копируется столько раз сколько есть строк в базе данных
Миниатюры
Перенос отфильтрованных строк из DBGrid в Exel  
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
09.04.2019, 14:59
Лучший ответ Сообщение было отмечено 375447575257 как решение

Решение

попробуйте так:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
procedure TForm2.Button6Click(Sender: TObject);
var
ExcelApp : variant;
row :integer;
col:integer;
begin
  form2.DBGRID1.DataSource.DataSet.First;
  ExcelApp:=CreateOleObject('Excel.Application');
  ExcelApp.workbooks.open(ExtractFilePath(ParamStr(0))+'reestr.xls');
  ExcelApp.Visible := false;
  row := 0;
  while not form2.DBGrid1.DataSource.DataSet.eof do begin
    for col := 0 to form2.DBGrid1.Columns.Count-1 do begin
       ExcelApp.WorkBooks[1].WorkSheets[1].cells[row+4,col+2].value:=form2.DBgrid1.DataSource.DataSet.Fields[col].AsString;
       ExcelApp.WorkBooks[1].WorkSheets[1].cells[row+4,1]:=row+1;
    end;
    form2.Dbgrid1.DataSource.DataSet.Next;
    inc(row);
  end;
ExcelApp.Visible := True;
end;
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.04.2019, 14:59
Помогаю со студенческими работами здесь

Перенос записей из одного DBGrid в другой DBGrid
Здравствуйте. Есть проблема! Ни как ни получается перенос записей Вот текст кода: procedure TF_Licenzie.DBGrid1CellClick(Column:...

Вывод из DBGrid в Exel
В access создала 4 таблицы некоторые данные из этих таблиц объединила в access. Потом в Delphi с помощью компонентов ADOConnection,...

Перенос данных из DBGrid в DBGrid
Есть два DBGrid. Данные в них получаем из Excel. Таблицы разные. Но есть одинаково названные колонки: "Код", "Наименование...

Перенос отфильтрованных строк Excel
Всем привет! У меня возникла проблема. Есть колонка, где находятся и названия компаний и сами имена. Компании заключены в кавычки,...

Перенос данных из одного файла Exel в другой файл Exel
Добрый день всем! Копался сам, но так и не нашел ответа. Вопрос следующий. Есть временный файл эксель(после работы с ним удаляется)....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru