日期业务处理 Windows C# 上的服务
Date business handling Windows Service on C#
我有一个需求,我需要在日期字段上工作,每天我需要管理一个发送和接收磁带来处理备份,但是操作员有任何特殊条件,他们没有人同意在假期工作,所以要求是这样的
我会运行一个每次查业务日期的服务,需要接线员在假期或周末(周六和周日)之前发送磁带驱动器:
我有一个 table 的大师假期,所以我会在当前 table 寻找假期。
如果前。今天是星期一,服务第一次开始。明天周二是假期,所以我必须在周一处理周二的所有工作。
如果前。今天是星期一,服务第一次开始。而且明天周二和周三是假期,所以我必须在周一处理周二和周三的所有工作。
如果前。今天是星期一,服务第一次开始。明天周四是假期,所以我必须在周三处理所有周四的工作。
一个流程带落在周六和周日,如果周五不是节假日,则必须在周五处理,如果假期则周五至周日的流程带,将在周四处理,并继续这样处理如果明天是节假日,那么必须在明天之前处理非节假日的日期。
当我第一次 运行ning 服务 Ex 在星期一和星期二和星期三是假期时出现问题,我怎么知道?其实我也不知道,怎么知道明天是不是放假才能继续处理。
我已经尝试通过多个 if 和 else 案例来解决上述问题,但只是想知道是否有任何通用且优雅的方法来解决这个问题?
我想不出通用的方法,因为假期通常是对打算使用您的服务的国家或组织的任意计算。根据我的说法,您必须将 send/process 磁带和假日列表的服务逻辑分开。当您定义假期列表(在 db table 中或简单地在 xml 中)时,您应该能够定义诸如日期之类的内容和一个标志来表示它是否是假期。
现在当你的服务执行时,它首先检查当天是否是假期;如果是这样,它可以跳过磁带加载,否则加载当天和其余连续假期的磁带(查找从当前日期到下一个工作日的其他假期)。
Actually I didn't know, how we can to know if tomorrow is holiday to continue process.
我不确定我是否理解这个问题,因为您可以像测试今天是否一样来测试明天是否是假期。假期日期的部分列表:
hList = new List<Holiday>();
hList.Add(new Holiday("Thanksgiving", new DateTime(2016, 11, 24)));
hList.Add(new Holiday("Black Friday", new DateTime(2016, 11, 25)));
hList.Add(new Holiday("May Day", new DateTime(2016, 05, 1)));
hList.Add(new Holiday("Memorial Day", new DateTime(2016, 5, 30)));
hList.Add(new Holiday("Cinco", new DateTime(2016, 5, 5)));
hList.Add(new Holiday("FooBar Day", new DateTime(2016, 5, 18)));
// like Carnival without the hangover:
hList.Add(new Holiday("Ziggy Festival", new DateTime(2016, 2, 9)));
hList.Add(new Holiday("Ziggy Festival", new DateTime(2016, 2, 10)));
hList.Add(new Holiday("Ziggy Festival", new DateTime(2016, 2, 11)));
这些是使用的更大列表中有趣的列表。偶然地,其中大多数创建了 holiday/weekends 的多天序列。 FooBar Day 是一个单一的日子。
一份工作清单 class 用于积累未来的工作天数:
public class WorkItem
{
// on this day...
public DateTime Date { get; set; }
// do work for these days:
public List<DateTime> Tasks { get; private set; }
public WorkItem(DateTime d)
{
Date = d.Date;
Tasks = new List<DateTime>();
}
public void AddDay(DateTime dt)
{
if (!Tasks.Contains(dt.Date))
Tasks.Add(dt.Date);
}
}
testDates 列表是每个假期条目前后 3 天的每个日期。扫描并创建工作列表:
private void CreateHolidayWorkList()
{
WorkItem w;
wList = new List<WorkItem>();
foreach (DateTime dt in testDates)
{
// if today is Holiday, skip
if (!IsHolidayOrWeekend(dt))
{
// is TOMORROW a holiday or weekend??
// AndAlso is it not alreay in the list
if (IsHolidayOrWeekend(dt.AddDays(1)) &&
wList.FirstOrDefault(f=> f.Date.Date==dt.Date)==null)
{
// current To-Do date
w = new WorkItem(dt);
// scan ahead up to 6 days to find consecutive
// holiday/weekend dates
for (int n = 1; n <= 6; n++)
{
if (IsHolidayOrWeekend(dt.AddDays(n)))
w.AddDay(dt.AddDays(n));
else
break;
}
// add todo list to list
wList.Add(w);
}
}
}
}
private bool IsHolidayOrWeekend(DateTime dt)
{
if (dt.DayOfWeek == DayOfWeek.Saturday || dt.DayOfWeek == DayOfWeek.Sunday)
return true;
return (hList.FirstOrDefault(q => q.Date == dt) != null);
}
部分结果:
on 2016-02-08 Do work for:
-> 2016-02-09
-> 2016-02-10
-> 2016-02-11
on 2016-02-12 Do work for:
-> 2016-02-13
-> 2016-02-14
...
on 2016-05-04 Do work for:
-> 2016-05-05
on 2016-05-17 Do work for:
-> 2016-05-18
...
on 2016-11-10 Do work for:
-> 2016-11-11
-> 2016-11-12
-> 2016-11-13
on 2016-11-23 Do work for:
-> 2016-11-24
-> 2016-11-25
-> 2016-11-26
-> 2016-11-27
- 工作列表不包括
之前的最后一个工作日
- 2/8 作品清单是为为期 3 天的 Ziggy Festival
- 2/12 列表是 "accidental" 测试日期。它被包括在内是因为它距离 Ziggy Festival 最后一天不到 3 天。这是周末的标准周五清单
- 5/4 和 5/17 承认单日假期
- 最后两个只是显示很长的假期字符串
我有一个需求,我需要在日期字段上工作,每天我需要管理一个发送和接收磁带来处理备份,但是操作员有任何特殊条件,他们没有人同意在假期工作,所以要求是这样的
我会运行一个每次查业务日期的服务,需要接线员在假期或周末(周六和周日)之前发送磁带驱动器:
我有一个 table 的大师假期,所以我会在当前 table 寻找假期。
如果前。今天是星期一,服务第一次开始。明天周二是假期,所以我必须在周一处理周二的所有工作。
如果前。今天是星期一,服务第一次开始。而且明天周二和周三是假期,所以我必须在周一处理周二和周三的所有工作。
如果前。今天是星期一,服务第一次开始。明天周四是假期,所以我必须在周三处理所有周四的工作。
一个流程带落在周六和周日,如果周五不是节假日,则必须在周五处理,如果假期则周五至周日的流程带,将在周四处理,并继续这样处理如果明天是节假日,那么必须在明天之前处理非节假日的日期。
当我第一次 运行ning 服务 Ex 在星期一和星期二和星期三是假期时出现问题,我怎么知道?其实我也不知道,怎么知道明天是不是放假才能继续处理。
我已经尝试通过多个 if 和 else 案例来解决上述问题,但只是想知道是否有任何通用且优雅的方法来解决这个问题?
我想不出通用的方法,因为假期通常是对打算使用您的服务的国家或组织的任意计算。根据我的说法,您必须将 send/process 磁带和假日列表的服务逻辑分开。当您定义假期列表(在 db table 中或简单地在 xml 中)时,您应该能够定义诸如日期之类的内容和一个标志来表示它是否是假期。 现在当你的服务执行时,它首先检查当天是否是假期;如果是这样,它可以跳过磁带加载,否则加载当天和其余连续假期的磁带(查找从当前日期到下一个工作日的其他假期)。
Actually I didn't know, how we can to know if tomorrow is holiday to continue process.
我不确定我是否理解这个问题,因为您可以像测试今天是否一样来测试明天是否是假期。假期日期的部分列表:
hList = new List<Holiday>();
hList.Add(new Holiday("Thanksgiving", new DateTime(2016, 11, 24)));
hList.Add(new Holiday("Black Friday", new DateTime(2016, 11, 25)));
hList.Add(new Holiday("May Day", new DateTime(2016, 05, 1)));
hList.Add(new Holiday("Memorial Day", new DateTime(2016, 5, 30)));
hList.Add(new Holiday("Cinco", new DateTime(2016, 5, 5)));
hList.Add(new Holiday("FooBar Day", new DateTime(2016, 5, 18)));
// like Carnival without the hangover:
hList.Add(new Holiday("Ziggy Festival", new DateTime(2016, 2, 9)));
hList.Add(new Holiday("Ziggy Festival", new DateTime(2016, 2, 10)));
hList.Add(new Holiday("Ziggy Festival", new DateTime(2016, 2, 11)));
这些是使用的更大列表中有趣的列表。偶然地,其中大多数创建了 holiday/weekends 的多天序列。 FooBar Day 是一个单一的日子。
一份工作清单 class 用于积累未来的工作天数:
public class WorkItem
{
// on this day...
public DateTime Date { get; set; }
// do work for these days:
public List<DateTime> Tasks { get; private set; }
public WorkItem(DateTime d)
{
Date = d.Date;
Tasks = new List<DateTime>();
}
public void AddDay(DateTime dt)
{
if (!Tasks.Contains(dt.Date))
Tasks.Add(dt.Date);
}
}
testDates 列表是每个假期条目前后 3 天的每个日期。扫描并创建工作列表:
private void CreateHolidayWorkList()
{
WorkItem w;
wList = new List<WorkItem>();
foreach (DateTime dt in testDates)
{
// if today is Holiday, skip
if (!IsHolidayOrWeekend(dt))
{
// is TOMORROW a holiday or weekend??
// AndAlso is it not alreay in the list
if (IsHolidayOrWeekend(dt.AddDays(1)) &&
wList.FirstOrDefault(f=> f.Date.Date==dt.Date)==null)
{
// current To-Do date
w = new WorkItem(dt);
// scan ahead up to 6 days to find consecutive
// holiday/weekend dates
for (int n = 1; n <= 6; n++)
{
if (IsHolidayOrWeekend(dt.AddDays(n)))
w.AddDay(dt.AddDays(n));
else
break;
}
// add todo list to list
wList.Add(w);
}
}
}
}
private bool IsHolidayOrWeekend(DateTime dt)
{
if (dt.DayOfWeek == DayOfWeek.Saturday || dt.DayOfWeek == DayOfWeek.Sunday)
return true;
return (hList.FirstOrDefault(q => q.Date == dt) != null);
}
部分结果:
on 2016-02-08 Do work for:
-> 2016-02-09
-> 2016-02-10
-> 2016-02-11
on 2016-02-12 Do work for:
-> 2016-02-13
-> 2016-02-14
...
on 2016-05-04 Do work for:
-> 2016-05-05
on 2016-05-17 Do work for:
-> 2016-05-18
...
on 2016-11-10 Do work for:
-> 2016-11-11
-> 2016-11-12
-> 2016-11-13
on 2016-11-23 Do work for:
-> 2016-11-24
-> 2016-11-25
-> 2016-11-26
-> 2016-11-27
- 工作列表不包括 之前的最后一个工作日
- 2/8 作品清单是为为期 3 天的 Ziggy Festival
- 2/12 列表是 "accidental" 测试日期。它被包括在内是因为它距离 Ziggy Festival 最后一天不到 3 天。这是周末的标准周五清单
- 5/4 和 5/17 承认单日假期
- 最后两个只是显示很长的假期字符串