[英]Date Comparison in Groovy SAP CPI
We are trying to compare dates using the below if-else condition.If we use constant values,the conditions are evaluated correctly.However when we use the references of array values the code doesn't work as expected.我们正在尝试使用下面的 if-else 条件比较日期。如果我们使用常量值,条件会被正确评估。但是,当我们使用数组值的引用时,代码不会按预期工作。 Request your guidance here.
在此处请求您的指导。
last Execution date you can take todays date.最后一个执行日期,您可以取今天的日期。
input payload:输入有效载荷:
<items>
<row>
<id>1</id>
<status__v>Approved</status__v>
<approved_date__c>2021-06-17</approved_date__c>
<major_version_number__v>1</major_version_number__v>
</row>
<row>
<id>2</id>
<status__v>Approved</status__v>
<approved_date__c>2021-08-30</approved_date__c>
<major_version_number__v>1</major_version_number__v>
</row>
<row>
<id>3</id>
<status__v>Approved</status__v>
<approved_date__c>2021-10-01</approved_date__c>
<major_version_number__v>1</major_version_number__v>
</row>
</items>
Groovy Code:常规代码:
import com.sap.it.api.mapping.*;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.io.*
import java.lang.*;
import java.util.*;
def void Itemstatus(String[] ApprovedDt,String[] status,String[] version,String[] propertyName, Output output,MappingContext context)
{
String lets = context.getProperty(propertyName[0]); // "lets" will get value "2021-09-30"
SimpleDateFormat formatter1=new SimpleDateFormat("yyyy-MM-dd");
datelets=formatter1.parse(lets);
Date date = new Date();
String CurrentDate = date.format("yyyy-MM-dd"); // "currentDate" value "2021-09-30"
def status1 = ["Active","Inactive"];
for(int i=0; i<status.size(); i++)
{
dateApprovedDt = formatter1.parse(ApprovedDt[i]); // "dateApprovedDt" value "2021-06-17"
if (status == "Approved" && dateApprovedDt > datelets)
{
output.addValue(status1[0])
}
else if(status == "Approved" && dateApprovedDt > datelets && version[i] > "1") //version value "1"
{
output.addValue(status1[0])
}
else if (status == "Approved" && dateApprovedDt < CurrentDate)
{
output.addValue(status1[1])
}
else
{
output.addValue(status1[2])
}
}
}
You are trying to compare a Date
with a String
in this line:您正在尝试在此行中将
Date
与String
进行比较:
else if (status == "Approved" && dateApprovedDt < CurrentDate)
You'd rather want to compare like so: dateApprovedDt < date
你宁愿像这样比较:
dateApprovedDt < date
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.