0

给定开始日期时间结束日期时间重复日期时间,我如何每周找到相同的时间表,直到重复日期时间

例如:

start date time: 05-29-2012 07:35
end date time: 05-29-2012 10:27 
repeat until date: 06-19-2012 09:00

结果将是:

06-05-2012 07:35 06-05-2012 10:27
06-12-2012 07:35 06-12-2012 10:27

知道如何在 cfml 中做到这一点吗?

这是我到目前为止所尝试的:

<cfset start_dt = "05-29-2012 07:35">
<cfset end_dt = "05-29-2012 10:27">
<cfset repeat_until = "06-19-2012 09:00">
<cfoutput>start: #start_dt#<br></cfoutput>
<cfoutput>end: #end_dt#<br></cfoutput>
<cfoutput>repeat until: #repeat_until#<br></cfoutput>
<cfset s_date='#DatePart("m", start_dt)#/#DatePart("d", start_dt)#/#DatePart("yyyy", start_dt)#'>
<cfoutput>#s_date#<br></cfoutput>
<cfset s_date = DateAdd("d", 7, s_date)>
<cfoutput>#s_date#<br></cfoutput>
4

1 回答 1

2

以您的预期结果示例为例,您似乎并不关心start_dtonly of的值end_dt。因此,这是一种可以让它发挥作用的方法。您只需要一种类型的循环,但我已经包括了两种,以便您可以选择自己的偏好。

<cfset start_dt = "05-29-2012 07:35">
<cfset end_dt = "05-29-2012 10:27">
<cfset repeat_until = "06-19-2012 09:00">
<cfoutput>start: #start_dt#<br></cfoutput>
<cfoutput>end: #end_dt#<br></cfoutput>
<cfoutput>repeat until: #repeat_until#<br></cfoutput>

<!--- FromTo loop --->
<cfset first_dt = DateAdd("d", 7, end_dt)>
<cfloop from="#first_dt#" to="#repeat_until#" index="current_dt" step="#CreateTimeSpan(7,0,0,0)#">
    <cfoutput>#DateFormat(current_dt, "mm-dd-yyyy")# #TimeFormat(current_dt, "HH:mm")#<br></cfoutput>
</cfloop>

<!--- Condition loop --->
<cfset current_dt = DateAdd("d", 7, end_dt)>
<cfloop condition="DateCompare(current_dt, repeat_until) LTE 0">
    <cfoutput>#DateFormat(current_dt, "mm-dd-yyyy")# #TimeFormat(current_dt, "HH:mm")#<br></cfoutput>
    <cfset current_dt = DateAdd("d", 7, current_dt)>
</cfloop>
于 2012-05-30T09:09:28.180 回答