我创建了几个带有时间表达式的变量,以创建基于时间的报告:

// First of month (Returns 01/09/2017)
 new SimpleDateFormat("MM/dd/yyyy").format(java.util.Date.parse("01/" + MONTH(NOW( )) + "/" + YEAR(NOW())))

// First of previous month (Returns 01/08/2017)
 new SimpleDateFormat("MM/dd/yyyy").format(java.util.Date.parse("01/" + (MONTH(NOW( )) - 1) + "/" + YEAR(NOW())))

// Last of month (Returns 30/09/2017)
 new SimpleDateFormat("MM/dd/yyyy").format(java.util.Date.parse(MONTH(NOW( )) + "/" + DAYSINMONTH(NOW())+ "/" + YEAR(NOW())))


我现在正在努力获取上个月的最后一天。我尝试了以下方法,但是由于所有月份的天数都不相同,因此当然无法正常工作。

// Last of previous month (Returns 30/08/2017)
 new SimpleDateFormat("MM/dd/yyyy").format(java.util.Date.parse(
  (MONTH(NOW( )) - 1)
  + "/" +
  DAYSINMONTH(NOW())
  + "/" +
  YEAR(NOW())
 ))


您是否知道检索上个月的最后一天的方法?

参考:http://community.jaspersoft.com/questions/843248/last-day-current-month

最佳答案

我可能已经解决了在Java中创建一个静态类的方法,该方法使用将日期作为参数的方法,然后使用Calendar api或类似方法返回所需的日期,这就是在Java Calendar - Get last day of previous month中执行此操作的方法。

但是,让我们玩得开心,只使用jasper报告

由于我们无法使用Calendar api(它返回void),因此我们需要在again上回退org.apache.commons.lang.time.DateUtils,因为我的朋友Tunaki教了我。

使用DateUtils我们可以先呼叫一个月(删除天),然后再呼叫truncate -1(-1天(如果我们在月份的第一个日期,则为-1天,它将给我们上个月的最后一个日期)

DateUtils.addDays(DateUtils.truncate(myDate, Calendar.MONTH),-1);


jrxml示例

<?xml version="1.0" encoding="UTF-8"?>
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="DateUtil" pageWidth="595" pageHeight="842" whenNoDataType="AllSectionsNoDetail" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="f288086f-db4e-451f-bf32-e1cce6311a27">
    <property name="com.jaspersoft.studio.data.defaultdataadapter" value="One Empty Record"/>
    <import value="java.util.Calendar"/>
    <import value="org.apache.commons.lang.time.DateUtils"/>
    <parameter name="date" class="java.util.Date">
        <defaultValueExpression><![CDATA[new Date()]]></defaultValueExpression>
    </parameter>
    <queryString>
        <![CDATA[]]>
    </queryString>
    <title>
        <band height="20" splitType="Stretch">
            <textField pattern="MM/dd/yyyy">
                <reportElement x="0" y="0" width="220" height="20" uuid="48878c52-5527-4784-a74a-e2d8df65cc55"/>
                <textFieldExpression><![CDATA[DateUtils.addDays(DateUtils.truncate($P{date}, Calendar.MONTH),-1)]]></textFieldExpression>
            </textField>
        </band>
    </title>
</jasperReport>


输出(我通过此答案的那天)

java - 如何显示相对于日期的上个月的最后一天?-LMLPHP


  设计说明:您应该像我在示例中那样使用模式来格式化日期,不要在表达式中使用addDays,如果将例如导出为ex​​cel,则使用模式将为您提供正确的对象。

10-04 22:59
查看更多