Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
 Аватар для dggrom
198 / 158 / 45
Регистрация: 23.08.2014
Сообщений: 807

JasperReports

05.07.2020, 18:29. Показов 738. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Пытаюсь с помощью данной библиотеки сформировать отчет и сохранить его в PDF.

Нашел пример в интернете и на основе его пытаюсь реализовать задачу.

Первый класс который создал для хранения данных отчета. Так же реализовал функцияю которая запросам получает данные из БД.

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package Sempel.Reports.PriceNomen;
 
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
 
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import sql.SelectPost;
import sql.SettingConnectSQL;
 
public class PersenReportPriceNomen {
 
    private Integer NP;
    private String NomenName;
    private Integer SumNomen;
    
    public PersenReportPriceNomen(Integer NP, String NomenName, Integer SumNomen){
        
        this.NP = NP;
        this.NomenName = NomenName;
        this.SumNomen = SumNomen;
        
    }
    
    public void setNP(Integer value) {this.NP = value;}
    public Integer getNP() {return this.NP;}
    
    public void setNomenName(String value) {this.NomenName = value;}
    public String getNomenName() {return this.NomenName;}
    
    public void setSumNomen(Integer value) {this.SumNomen = value;}
    public Integer getSumNomen() {return this.SumNomen;}
    
    public static ObservableList<PersenReportPriceNomen> getMassivReportPrice(SettingConnectSQL SetCon) throws SQLException {
        
        ObservableList<PersenReportPriceNomen> Mass = FXCollections.observableArrayList();
        
        Integer linePer = 0;
        String TextSQL = "SELECT Nom.name_nomen, RP.price_rp\n" + 
                "   FROM public.\"RegistrPrice\" RP, public.\"Nomenclature\" Nom\n" + 
                "   WHERE Nom.id_nomen = RP.id_nomen;";
        
        Connection Conn = SetCon.CreatConnect();
        SelectPost SelPos = new SelectPost();
        
        ResultSet ResSet = SelPos.SelectInfoBase(Conn, TextSQL);
        
        while(ResSet.next()) {
            linePer++;
            Mass.add(new PersenReportPriceNomen(linePer, ResSet.getString(1), ResSet.getInt(2)));
        }
        
        Conn.close();
        
        return Mass;
        
    }
    
}
Потом создал класс где пытаюсь уже сформировать отчет и сохранить его на диск.

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package Sempel.Reports.PriceNomen;
 
import java.io.File;
import java.sql.SQLException;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
 
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperExportManager;
import net.sf.jasperreports.engine.JasperCompileManager;
 
import net.sf.jasperreports.engine.xml.JRXmlLoader;
import net.sf.jasperreports.engine.design.JasperDesign;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
 
import javafx.collections.ObservableList;
import sql.SettingConnectSQL;
 
public class DataReportPriceNomen {
 
        private File                                           reportPattern;
        private Map<String, Object>                            parameters;
        private JRBeanCollectionDataSource                     beanColDataSource;
        private ObservableList<PersenReportPriceNomen>         dataBeanList;
 
        private JasperDesign jasperDesign;
        private JasperReport jasperReport;
        private JasperPrint  jasperPrint ;  
    
 
        public void creatREportPriceNomen(SettingConnectSQL SetCon) throws SQLException, JRException {
            
            ObservableList<PersenReportPriceNomen> dataBeanList = PersenReportPriceNomen.getMassivReportPrice(SetCon);
            
            parameters = new HashMap<String, Object>();
            parameters.put("DataReport", new Date());
            reportPattern = new File("/Sempel/Reports/PriceNomen/ReportsPriceA4.jrxml");
            jasperDesign  = JRXmlLoader.load(reportPattern);
            jasperReport  = JasperCompileManager.compileReport(jasperDesign);
            jasperPrint   = JasperFillManager.fillReport(jasperReport, 
                                                         parameters, 
                                                         beanColDataSource);
            
            JasperExportManager.exportReportToPdfFile(jasperPrint, 
                    "/home/dggrom/Документы/java/EclipseProject/PostgreSQL/src/Sempel/Reports/PriceNomen/reportPDF.pdf");
            
        }
 
}
Но почему то программа подает в ошибку на строчке
jasperDesign = JRXmlLoader.load(reportPattern);

Вот лог ошибки.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
Exception in thread "JavaFX Application Thread" java.lang.NoClassDefFoundError: org/apache/commons/digester/Digester
    at Sempel.Reports.PriceNomen.DataReportPriceNomen.creatREportPriceNomen(DataReportPriceNomen.java:47)
    at Sempel.MainForm.ControllerMainForm.lambda$5(ControllerMainForm.java:121)
    at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86)
    at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
    at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
    at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49)
    at javafx.event.Event.fireEvent(Event.java:198)
    at javafx.scene.control.MenuItem.fire(MenuItem.java:462)
    at com.sun.javafx.scene.control.skin.ContextMenuContent$MenuItemContainer.doSelect(ContextMenuContent.java:1405)
    at com.sun.javafx.scene.control.skin.ContextMenuContent$MenuItemContainer.lambda$createChildren$6(ContextMenuContent.java:1358)
    at com.sun.javafx.event.CompositeEventHandler$NormalEventHandlerRecord.handleBubblingEvent(CompositeEventHandler.java:218)
    at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:80)
    at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
    at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
    at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
    at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54)
    at javafx.event.Event.fireEvent(Event.java:198)
    at javafx.scene.Scene$MouseHandler.process(Scene.java:3757)
    at javafx.scene.Scene$MouseHandler.access$1500(Scene.java:3485)
    at javafx.scene.Scene.impl_processMouseEvent(Scene.java:1762)
    at javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2494)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:394)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:295)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleMouseEvent$2(GlassViewEventHandler.java:432)
    at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:410)
    at com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java:431)
    at com.sun.glass.ui.View.handleMouseEvent(View.java:555)
    at com.sun.glass.ui.View.notifyMouse(View.java:937)
    at com.sun.glass.ui.gtk.GtkApplication._runLoop(Native Method)
    at com.sun.glass.ui.gtk.GtkApplication.lambda$null$10(GtkApplication.java:245)
    at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.ClassNotFoundException: org.apache.commons.digester.Digester
    at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 44 more
Файл с шаблоном находится там где я указываю, в чем может быть проблема ?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.07.2020, 18:29
Ответы с готовыми решениями:

IDE NetBeans, JasperReports
Доброго времени суток! Я скачал плагин для Netbeans вот отсюда: http://plugins.netbeans.org/plugin/4425/ireport подключил, добавил к...

Как сделать в JasperReports чтобы текст отображался в самом низу страницы при выгрузке из системы отчета в формате HTML?
Отчет в JasperReports состоит из основных Detail и нижнего колонититула. Нижний колонтитул в формате PDF и RTF выгружается с самом низу...

JasperReports
Пытаюсь для вывода отчетов подключить Jasper, но пока никак не выходит. Все библиотеки, которые были в jasper положил в клиента в...


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

Или воспользуйтесь поиском по форуму:
1
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
05.07.2020, 19:13
Цитата Сообщение от dggrom Посмотреть сообщение
NoClassDefFoundError: org/apache/commons/digester/Digester
напсиано же все
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru