Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 11.12.2012
Сообщений: 33
Delphi 6-7

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

09.04.2019, 13:48. Показов 1470. Ответов 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 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru