我无法将从日历中提取的日期转换/比较到当前日期我在if语句下的eclipse中得到一条红线我的目标是根据行/单元格中的日期评估当前日期并选择/点击行/单元格旁边的按钮。
然而,要进入第二部分,我需要正确评估第一部分,即日期。
我的代码如下:
for (WebElement pd: payDates) {
LocalDate currentDate = LocalDate.now();
java.util.Date d = new SimpleDateFormat("yyyy-MM-dd").parse(currentDate.toString());
if (pd >= (d)) {
driver.findElement(By.xpath("//tr[starts-with(@id,'changeStartWeekGrid_row_')and not(starts-with(@id,'changeStartWeekGrid_row_column'))]/td[5]/span'" + reqIndex + "])/TBODY[@id='changeStartWeekGrid_rows_tbody']/TR[7]/TD[1]/DIV[1]/DIV[1]/DIV[1]")).click();
PS_OBJ_CycleData.donebtn(driver).click();
break;
} else {
reqIndex++;
PS_OBJ_CycleData.Nextbtn(driver).click();
}
}
} while (reqIndex < 7); /// do this 7 times;
------------ this works for me thanks for all your help -----------------
int reqIndex = 0;
dowhileloop: do {
//List<WebElement> payDates = driver.findElements(By.xpath("//table[@id='changeStartWeekGrid_rows_table']//tr[position()>1]/td[position()=5]"));
List < WebElement > payDates = driver.findElements(By.xpath("//tr[starts-with(@id,'changeStartWeekGrid_row_')and not(starts-with(@id,'changeStartWeekGrid_row_column'))]/td[5]/span"));
// 5th colunm date print test
List < String > texts = payDates.stream().map(WebElement::getText).collect(Collectors.toList());
System.out.println("date ->" + texts);
//** Begin third inner for-loop****
for (WebElement pd: payDates) { // begin inner for loop
SimpleDateFormat dateFormat = new SimpleDateFormat("dd/MM/yyyy");
Date payDate = dateFormat.parse(pd.getText());
System.out.println("sample-> " + dateFormat.format(payDate));
if (payDate.after(new Date())) {
System.out.println("inside for loop");
driver.findElement(By.xpath("//tr[starts-with(@id,'changeStartWeekGrid_row_')and not(starts-with(@id,'changeStartWeekGrid_row_column'))]/td[5]/span'" + reqIndex + "])/TBODY[@id='changeStartWeekGrid_rows_tbody']/TR[7]/TD[1]/DIV[1]/DIV[1]/DIV[1]")).click();
PS_OBJ_CycleData.donebtn(driver).click();
break dowhileloop;
}
} //** END third inner for-loop****
reqIndex++;
PS_OBJ_CycleData.Nextbtn(driver).click();
Thread.sleep(5000);
答案 0 :(得分:3)
Date
,Calendar
,SimpleDateFormat
)。仅使用 java.time 类。LocalDate
。 isBefore
,isAfter
和isEqual
方法首先,不要将旧的日期时间类与现代 java.time 类混合使用。请勿使用java.util.Date
,Calendar
,SimpleDateFormat
以及java.time
包中未找到的任何其他日期时间类。那些旧类是一个可怜的混乱,完全取代了 java.time 框架。很好的解决。
您的YYYY-MM-DD输入格式由标准ISO 8601定义。在解析/生成字符串时, java.time 类默认使用这些标准格式。因此无需指定格式化模式。
LocalDate.parse( "2018-01-23" )
将日期时间值作为文本进行交换时,请始终使用ISO 8601格式。避免使用其他格式,例如MM/dd/yyyy
。
LocalDate.now()
获取当前日期时,请始终传递所需/预期的时区。否则,您将隐式使用JVM的当前默认密码。可以随时通过JVM中任何应用程序的任何代码更改该默认值。
时区对于确定日期至关重要。对于任何给定的时刻,日期在全球范围内因地区而异。例如,在Paris France午夜后的几分钟是新的一天,而Montréal Québec中仍然是“昨天”。
如果未指定时区,则JVM会隐式应用其当前的默认时区。该默认值可能随时更改,因此您的结果可能会有所不同。最好明确指定您期望/预期的时区作为参数。
以continent/region
的格式指定proper time zone name,例如America/Montreal
,Africa/Casablanca
或Pacific/Auckland
。切勿使用诸如EST
或IST
之类的3-4字母缩写,因为它们不是真正的时区,不是标准化的,甚至不是唯一的(!)。
ZoneId z = ZoneId.of( "America/Montreal" ) ;
LocalDate today = LocalDate.now( z ) ;
如果要使用JVM的当前默认时区,请求它并作为参数传递。如果省略,则隐式应用JVM的当前默认值。最好是明确的,因为默认情况下可以在运行时期间由JVM中任何应用程序的任何线程中的任何代码随时更改。
ZoneId z = ZoneId.systemDefault() ; // Get JVM’s current default time zone.
在您完全解释 输入中的内容pd
对象之前,无法完全回答您的问题。
pd
是一个字符串吗?如果是这样,那里有什么样的文字?搜索DateTimeFormatter
类的堆栈溢出,以查找使用java.time将文本解析为日期时间对象的许多示例和讨论。
如果您的输入是01/23/2017
之类的字符串,请定义要匹配的格式设置模式。
String input = "01/23/2017" ;
DateTimeFormatter f = DateTimeFormatter.ofPattern( "MM/dd/uuuu" ) ; // Define a custom format to match input.
LocalDate ld = LocalDate.parse( input , f ) ;
如上所述,在将日期时间值作为文本进行交换时,请始终使用标准ISO 8601格式而不是自定义格式。
要比较LocalDate
个对象,请调用方法isBefore
,isAfter
和isEqual
。
boolean isFuture = someLocalDate.isAfter( today ) ;
java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和&amp; SimpleDateFormat
现在位于Joda-Time的maintenance mode项目建议迁移到java.time类。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310。
您可以直接与数据库交换 java.time 对象。使用符合JDBC driver或更高版本的JDBC 4.2。不需要字符串,不需要java.sql.*
类。
从哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
和more。
答案 1 :(得分:1)
将pd转换为日期(或更好,将其纪元转换为long(不推荐使用日期))并执行d.compare而不是&gt; =