Как создать динамический отчет полный jrxml?

Я работаю над jrxml для создания динамических отчетов. Я параметризовал столбцы, т.е. jrxml для того отчета может использоваться для генерации других отчетов также.

Однако мне не удалось сделать поля гибкими. Таким образом, если бы пользователь выбирает 4 столбца, это работало бы, но если 1 или 2 или 3 столбца выбраны, это дает ошибку, так как имена полей являются неопознанными.

Отправьте решение срочно, если что-то как выражение по умолчанию для имени поля может быть создано, или для сценария цикла/Java может использоваться.

Кроме того, как разработчик яшмы может точно использоваться для достижения этого?

jrxml следующие:

<?xml version="1.0"?>
<!DOCTYPE jasperReport
  PUBLIC "-//JasperReports//DTD Report Design//EN"
  "http://jasperreports.sourceforge.net/dtds/jasperreport.dtd">
<jasperReport name="report1">
    <parameter name="reportTitle" class="java.lang.String"/>
    <parameter name="author" class="java.lang.String"/>
    <parameter name="startDate" class="java.lang.String"/>

    <parameter name="C1" class="java.lang.String">
        <defaultValueExpression>
            new java.lang.String("")
        </defaultValueExpression>
    </parameter>
    <parameter name="C2" class="java.lang.String">
        <defaultValueExpression>
            new java.lang.String("")
        </defaultValueExpression>
    </parameter>
    <parameter name="C3" class="java.lang.String">
        <defaultValueExpression>
            new java.lang.String("")
        </defaultValueExpression>
    </parameter>
    <parameter name="C4" class="java.lang.String">
        <defaultValueExpression>
            new java.lang.String("default parameter value")
        </defaultValueExpression>
    </parameter>

    <field name="COLUMN_1" class="java.lang.Integer"/>
    <field name="COLUMN_2" class="java.lang.Integer"/>
    <field name="COLUMN_3" class="java.lang.Integer"/>
    <field name="COLUMN_4" class="java.lang.Integer"/>

    <title>
        <band height="60">
            <textField>
                <reportElement x="0" y="10" width="500" height="40"/>
                <textElement textAlignment="Center">
                    <font size="24"/>
                </textElement>
                <textFieldExpression class="java.lang.String">
                    <![CDATA[$P{reportTitle}]]>
                </textFieldExpression>
            </textField>
            <textField>
                <reportElement x="0" y="40" width="500" height="20"/>
                <textElement textAlignment="Center"/>
                <textFieldExpression class="java.lang.String">
                    <![CDATA["Run by: " + $P{author}
                        + " on " + $P{startDate}]]>
                </textFieldExpression>
            </textField>
        </band>
    </title>

    <columnHeader>
        <band height="30">
            <rectangle>
                <reportElement x="0" y="0" width="500" height="25"/>
                <graphicElement/>
            </rectangle>

            <textField>
                <reportElement x="0" y="5" width="170" height="15"/>
                <textFieldExpression class="java.lang.String">
                    <![CDATA[$P{C1}]]>
                </textFieldExpression>
            </textField>

            <textField>
                <reportElement x="70" y="5" width="170" height="15"/>
                <textFieldExpression class="java.lang.String">
                    <![CDATA[$P{C2}]]>
                </textFieldExpression>
            </textField>

            <textField>
                <reportElement x="150" y="5" width="150" height="15"/>
                <textFieldExpression class="java.lang.String">
                    <![CDATA[$P{C3}]]>
                </textFieldExpression>
            </textField>

            <textField>
                <reportElement x="300" y="5" width="150" height="15"/>
                <textFieldExpression class="java.lang.String">
                    <![CDATA[$P{C4}]]>
                </textFieldExpression>
            </textField>
        </band>
    </columnHeader>

    <detail>
        <band height="20">
            <textField>
                <reportElement x="5" y="0" width="50" height="15"/>
                <textElement/>
                <textFieldExpression class="java.lang.Integer">
                    <![CDATA[$F{COLUMN_1}]]>
                </textFieldExpression>
            </textField>

            <textField>
                <reportElement x="90" y="0" width="150" height="15"/>
                <textElement/>
                <textFieldExpression class="java.lang.Integer">
                    <![CDATA[$F{COLUMN_2}]]>
                </textFieldExpression>
            </textField>

            <textField>
                <reportElement x="170" y="0" width="50" height="15"/>
                <textElement/>
                <textFieldExpression class="java.lang.Integer">
                    <![CDATA[$F{COLUMN_3}]]>
                </textFieldExpression>
            </textField>

            <textField>
                <reportElement x="320" y="0" width="150" height="15"/>
                <textElement/>
                <textFieldExpression class="java.lang.Integer">
                    <![CDATA[$F{COLUMN_4}]]>
                </textFieldExpression>
            </textField>
        </band>
    </detail>
</jasperReport>
5
задан Alex K 20 June 2012 в 06:20
поделиться

1 ответ

Если вы хотите, чтобы он был динамическим, как при скрытии / отображении новых полей, я думаю, что единственный способ - изменить ваш jrxml во время выполнения и скомпилировать его.

ОБНОВЛЕНИЕ:

Чтобы сделать JasperReport динамическим во время выполнения, у вас есть три подхода:

1. Создание JRXML в iReport
Если ваш отчет сложный и содержит много вложенных отчетов и наборов данных, лучше использовать этот подход, поскольку iReport позволит вам быстрее и проще разрабатывать и поддерживать в дальнейшем.
Следуя этому подходу, вы создадите файл jrxml и сохраните его в пути к классам, во время выполнения вы загрузите этот файл, откроете его и измените нужные теги XML. Я бы рекомендовал начать с jrxml, который включает максимальное количество столбцов, а затем, если пользователь выберет меньше столбцов, найдите эти дополнительные столбцы в jrxml и удалите их.

2. Создание всего отчета на Java
Этот подход лучше, если ваш отчет действительно прост, как быстрый табличный отчет, в этом случае вам не нужен файл jrxml, вы можете создать весь отчет во время выполнения с нуля, используя API библиотеки JasperReport. Такой подход усложнит разработку отчета, поскольку вы ничего не увидите, пока не скомпилируете и не запустите. Еще хуже то, что это кошмар обслуживания.
Ваш окончательный исходный код Java будет выглядеть примерно так: «Тест фиксированной ширины столбца» 1

3. Используйте DynamicJasper
Наконец, если вы открыты для новых инструментов, всегда есть DynamicJasper , вы также можете проверить онлайн-демонстрацию , это довольно круто.
Я оставил DJ на конец, чтобы показать вам все подходы, DJ на самом деле использует второй. Создание исходного кода Java отчета на лету.


1: Авторские права на отчет о тестировании фиксированной ширины столбца принадлежат DynamicJasper и используются здесь только в качестве образца.

3
ответ дан 15 December 2019 в 06:28
поделиться
Другие вопросы по тегам:

Похожие вопросы: