译:Datetime类型的扩展
译文出处:http://www.codeproject.com/Articles/870939/Datetime-Extensions
本文主要针对System.DateTime类型的一系列扩展。包括不同语言环境下对节假日和工作日时间的计算。
简介:
这个开源的项目是对System.DateTime类型的一系列扩展。包括在不同语言环境下节假日和工作日的时间计算。
在许多的企业中,都有一个工作日的概念。无论是计算工作流的完成日期还是回电话,除了节假日和周末,许多企业都从一个日期来增加或减少天数的方式来定义工作日。
你可以从下面链接来下载开放的源码:https://github.com/kappy/DateTimeExtensions
背景:
一个企业的节假日或周末都受到了企业的政策和地理位置的影响,而不是同一某个经验法则来计算的。这里是通过一个DateTimeCultureInfo对象来定义工作日的。
DateTimeCultureInfo是 一个基于具体文化来处理日期的核心类。它定义了如何判断一个给出的日期是不是工作日,和两个不同日期之间的转化。
处理工作日依赖于下面2个方法:
public bool IsWorkingDay(DayOfWeek dayOfWeek)
public bool IsWorkingDay(DateTime date)
第一个方法用来确定一周内的工作日,第二个方法作为第一个的扩展,来处理节假日。
由于有多种文化的工作日,所以定义了一个Name属性。
执行这些方法都有具体的策略 IWorkingDayOfWeekStrategy和IHolidayStrategy两个接口。这样设计师为了提高扩展性。
作为辅助功能,这个类能够定位,从约定和策略来实现上述两个接口。
默认情况下,策略是从CultureInfo类来定位的。
代码的使用:
下面的例子采用了最简单的方式来使用扩展:
[Test]
public void simple_calculation() {
var friday = new DateTime(,,); // A friday
var friday_plus_two_working_days = friday.AddWorkingDays(); // friday + 2 working days Assert.IsTrue(friday_plus_two_working_days == friday.AddDays());
Assert.IsTrue(friday_plus_two_working_days.DayOfWeek == DayOfWeek.Tuesday);
}
版本1.1中还有一个扩展来列出一年中的所有节假日:
IDictionary<DateTime, Holiday> AllYearHolidays(this DateTime date)
通过这个DateTime扩展,能够获得给定文化中一年的节假日。就像下面的例子:
[Test]
public void get_this_year_holidays_in_portugal() {
var portugalDateTimeCultureInfo = new DateTimeCultureInfo("pt-PT");
var today = DateTime.Today;
var holidays = today.AllYearHolidays(); Assert.IsTrue(holidays.Count == ); foreach (DateTime holidayDate in holidays.Keys) {
var holiday = holidays[holidayDate];
Assert.IsTrue(holidayDate.IsWorkingDay(portugalDateTimeCultureInfo) == false, "holiday {0} shouln't be working day in Portugal", holiday.Name);
}
}
目前支持的环境:
pt-PT
da-DK
pt-BR
fi-FI
en-US
is-IS
en-GB
nb-NO
fr-FR
nl-NL
de-DE
sv-SE
es-ES
es-AR
es-MX
en-AU
en-ZA
fr-CA (en-CA)
ar-SA
it-IT
en-NZ
en-GD
en-IE
sl-SL
扩展:
下面是扩展的两个要点。首先要实现自定义的IHolidayStrategy 和
IWorkingDayOfWeekStrategy接口。其次是实现所有的自定义IWorkingDayCultureInfo接口。最终2个的结果应该是相同的。
下面是实现一个自定义的IHolidayStrategy接口,定义了一个今天永远是假日的方法。
public class CustomHolidayStrategy : IHolidayStrategy {
public bool IsHoliDay(DateTime day) {
if (day.Date == DateTime.Today)
return true;
return false;
} public IEnumerable<Holiday> Holidays {
get { return null; }
}
} [Test]
public void provide_custom_strategies() {
var customDateTimeCultureInfo = new DateTimeCultureInfo() {
LocateHolidayStrategy = (name) => new CustomHolidayStrategy() ,
}; Assert.IsTrue(DateTime.Today.IsWorkingDay(customDateTimeCultureInfo) == false);
Assert.IsTrue(DateTime.Today.AddDays().IsWorkingDay(customDateTimeCultureInfo) == true);
}
下面这个例子定义了一个方法,能够实现一周有3天假期(即使这个具体的例子和实际生活中有所不同,轮流转多出来的一天假中会是在周末以外):
public class CustomDateTimeCultureInfo : IDateTimeCultureInfo {
public bool IsWorkingDay(DateTime date) {
return true;
} public bool IsWorkingDay(DayOfWeek dayOfWeek) {
switch (dayOfWeek) {
case DayOfWeek.Sunday:
case DayOfWeek.Saturday:
case DayOfWeek.Friday:
return false;
default:
return true;
}
} public IEnumerable<Holiday> Holidays {
get {
return null;
}
} public string Name {
get { return "Hello World!"; }
}
} [Test]
public void provide_custom_culture() {
var customDateTimeCultureInfo = new CustomDateTimeCultureInfo();
var today = DateTime.Today;
var next_friday = today.NextDayOfWeek(DayOfWeek.Friday); Assert.IsTrue(next_friday.IsWorkingDay(customDateTimeCultureInfo) == false);
}
致谢:~~~~~~~~~
译:Datetime类型的扩展的更多相关文章
- 【AspNetCore】【WebApi】扩展Webapi中的RouteConstraint中,让DateTime类型,支持时间格式化(DateTimeFormat)
扩展Webapi中的RouteConstraint中,让DateTime类型,支持时间格式化(DateTimeFormat) 一.背景 大家在使用WebApi时,会用到DateTime为参数,类似于这 ...
- C#3.0新特性:隐式类型、扩展方法、自动实现属性,对象/集合初始值设定、匿名类型、Lambda,Linq,表达式树、可选参数与命名参数
一.隐式类型var 从 Visual C# 3.0 开始,在方法范围中声明的变量可以具有隐式类型var.隐式类型可以替代任何类型,编译器自动推断类型. 1.var类型的局部变量必须赋予初始值,包括匿名 ...
- 使用Newtonsoft.json 解决 Asp.Net MVC DateTime类型数据Json格式化问题
解决思路 众所周知,MVC中调用的微软的组件JavaScriptSerialer...,格式DateTime类型数据需要在客户端专门解. 还知道,NewtonSoft.json可以“正确”的格式化Da ...
- 解决python中转化成json的方法不能序列化datetime类型数据(转)
Python自带的json.dumps方法序列化数据时候如果格式化的数据中有datetime类型数据时候会提示错误TypeError: datetime.datetime(2012, 12, 12, ...
- 解决Entity Framework中DateTime类型字段异常
从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值 具体的错误原因是:C#中的DateTime类型比SqlServer中的datetime范围大.SqlServe ...
- 用js解析经json序列化后的C#的DateTime类型数据
格式化日期(网上到处是),把下面的代码添加到jQuery.js文件中 //格式化日期 Date.prototype.format = function(format) { /* * eg:format ...
- Convert.ToDateTime(值),方法可以把一个值转化成DateTime类型。
例子:将日历控件的值转化成DateTime类型. DateTime beginDate = Convert.ToDateTime(this.beginCalendar.EditValue);
- 向数据库中插入一个DateTime类型的数据到一个Date类型的字段中,需要转换类型。TO_DATE('{0}','YYYY-MM-DD'))
需要指出的是,C#中有datetime类型,但是这个类型是包括小时,分钟,秒的.这个格式与数据库中的Date类型不符,如果将now设为datetime类型插入数据会失败. 需要通过TO_DATE('字 ...
- linq查询结果datetime类型转string类型
var list = new SupplierLogic().GetSupplier(pageSize, pageIndex).Select(q => new { SupplierID = q. ...
随机推荐
- dapper 操作类封装
using System; using System.Collections.Generic; using System.Data; using System.Data.SQLite; using S ...
- LeetCode: Remove Nth Node From End of List 解题报告
Remove Nth Node From End of List Total Accepted: 46720 Total Submissions: 168596My Submissions Quest ...
- ArcGIS与SuperMap的使用比较(1)
用了超过6年的超图产品了,因此对超图的很多特性比较熟悉,去年开始接触ARCGIS,并用来研发了一些新产品,因此对于两个GIS平台有些感受,记录如下: 比较版本:ARCGIS10.1与SuperMap ...
- linux系统和依赖包常用下载地址
http://ftp.gnome.org/pub/gnome/sources/gstreamer/0.10/ http://www.linuxfromscratch.org/blfs/view/svn ...
- Java WebService 简单实例[转]
http://www.cnblogs.com/yisheng163/p/4524808.html?utm_source=tuicool 前言:朋友们开始以下教程前,请先看第五大点的注意事项,以避免不必 ...
- 在android studio中导入github下载的工程
1.从Github中下载工程压缩包,并将其解压到本地 2.修改文件 假设,解压后的文件目录如下: (1)修改配置文件 xx\build.gradle // Top-level build file ...
- redhat下mysql安装与使用
1.安装 (1)查看是否安装 yum list installed mysql* (2)查看现有安装包 yum list mysql* (3)安装mysql服务器端 yum install mysql ...
- 【汇总】iOS开发及Xcode使用中遇到的一些报错问题汇总
这里整合下在开发过程中遇到过的一些报错问题和解决办法:(今天开始逐渐增加) Xcode编译错误集锦:http://www.cnblogs.com/ios-wmm/p/3402261.html ...
- XCode使用自带SVN,SVN命令
转载http://blog.sina.com.cn/s/blog_68661bd80101phpy.html 这两天响应老板要求,把所有代码放到公司的SVN服务器上,按照我的想法肯定是就苹果组建一个服 ...
- c# 靠谱的bitmap转byte[]
public static byte[] Bitmap2Byte(Bitmap bitmap) { using (MemoryStream stream = new MemoryStream()) { ...