С Новым годом! Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/21: Рейтинг темы: голосов - 21, средняя оценка - 4.57
6 / 6 / 4
Регистрация: 11.12.2011
Сообщений: 142
1

FastReport

22.05.2013, 22:30. Показов 4126. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем доброго время суток. Делаю отчёты в FastReport'e да вот никак не могу обработать деление на ноль.
Вот мои попытки:
Delphi
1
2
3
4
if (<ADOQuery1."Льготники">=nil) then memo27.memo.text:='0'
else memo27.memo.text:='[<ADOQuery1."Количество рецептов">/<ADOQuery1."Льготники">]';
if  (<ADOQuery1."Льготники">=nil) then memo28.memo.text:='0'                                              
else memo28.memo.text:='[SUM(<ADOQuery1."Количество рецептов">/<ADOQuery1."Льготники">)]';
Как видно из кода данные я получаю из ADOQuery1 и сверяю их с нулём(пробовал 0, но FastReport меня не понял, а вот при использовании Nil начал отлавливать ноль) отлавливает ноль в первой записи данных. Попробовал создать цикл для хождения по ADOQuery1, вот только проблема что вначале срабатывание код в FastReport'e, а уже потом строится отчёт и получается что теперь берёт он только данные с последней записи. Может кто работал с отчётами в этой программе и поможет с решением данной проблемы. Надеюсь на ваш опыт.

Вот цикл пока только по 3 записям в базе т.к. всего там 3 записи.
Delphi
1
2
3
4
5
6
7
8
9
10
11
var i:integer;                                 
begin                                   
for i:=1 to 3 do
begin            
if (<ADOQuery1."Льготники">=nil) then memo27.memo.text:='0'
else memo27.memo.text:=FloatToStr(<ADOQuery1."Количество рецептов">/<ADOQuery1."Льготники">);
if  (<ADOQuery1."Льготники">=nil) then memo28.memo.text:='0'                                              
else memo28.memo.text:=FloatToStr(SUM(<ADOQuery1."Количество рецептов">)/<ADOQuery1."Льготники">);
ADOQuery1.next;                                
end;    
end.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.05.2013, 22:30
Ответы с готовыми решениями:

FastReport 5
Здравствуйте, у меня есть несколько вопросов по генератору отчетов ФастРепорт. Помогите пожалуйста,...

fastreport
Может у кого есть пример как передовать fastreport свои данные из dbgrid ? Как это реализовать ?...

FastReport в Delphi
Такая проблема, в отчете FastReport неактивна кнопка New Dialog Page. Почитал мануал к FastReport,...

Fastreport frxMailExport
Нигде не могу найти инфы, крайне ограничена по фастрепорту... Как работать с данным компонентом,...

2
263 / 109 / 26
Регистрация: 16.03.2013
Сообщений: 272
22.05.2013, 23:54 2
Я работаю через fastreport (правда он встроен в стороннюю программу) с oracle. И если нужно что-то на что-то делить и есть вероятность, что знаменатель равен нулю, я просто проверяю это не через фастрепорт, а в самом запросе.
0
6 / 6 / 4
Регистрация: 11.12.2011
Сообщений: 142
23.05.2013, 14:05  [ТС] 3
Нашёл одну функцию для обработки. Если кому надо то вот:
Delphi
1
[iif(<ADOQuery1."Льготники">=0,0,<ADOQuery1."Количество рецептов">/<ADOQuery1."Льготники">)]
0
23.05.2013, 14:05
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
23.05.2013, 14:05
Помогаю со студенческими работами здесь

Установка FastReport
В просторах инета толком не сказано как правильно компилировать fastreport для delphi2010. В...

Delphi7 и FastReport 4.0
Доброго времени. Все утро бьюсь с установкой FR 4.0 в Delphi 7. Я скачал FR 4.0. Распаковал в...

Отчет в FastReport 4.6
Здравствуйте, подскажите, необходимо сделать что бы при формировании отчета если определенная...

CheckListBox ==> FastReport
Имеется TCheckListBox с определенным количеством записей. Пользователь в зависимости от ситуации...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru