//C# 计算时间差 用timespan函数
//TimeSpan 结构 表示一个时间间隔。
//命名空间:System
//程序集:mscorlib(在 mscorlib.dll 中)
//1.DateTime值类型代表了一个从公元0001年1月1日0点0分0秒到公元9999年12月31日23点59分59秒之间的具体日期时
刻。因此,你可以用DateTime值类型来描述任何在想象范围之内的时间。一个DateTime值代表了一个具体的时刻
//2.TimeSpan值包含了许多属性与方法,用于访问或处理一个TimeSpan值
//下面的列表涵盖了其中的一部分:
//Add:与另一个TimeSpan值相加。
//Days:返回用天数计算的TimeSpan值。
//Duration:获取TimeSpan的绝对值。
//Hours:返回用小时计算的TimeSpan值
//Milliseconds:返回用毫秒计算的TimeSpan值。
//Minutes:返回用分钟计算的TimeSpan值。
//Negate:返回当前实例的相反数。
//Seconds:返回用秒计算的TimeSpan值。
//Subtract:从中减去另一个TimeSpan值。
//Ticks:返回TimeSpan值的tick数。
//TotalDays:返回TimeSpan值表示的天数。
//TotalHours:返回TimeSpan值表示的小时数。
//TotalMilliseconds:返回TimeSpan值表示的毫秒数。
//TotalMinutes:返回TimeSpan值表示的分钟数。
//TotalSeconds:返回TimeSpan值表示的秒数。
//TimeSpan( 10, 20, 30, 40, 50 ) 10.20:30:40.0500000
//TimeSpan( 1111, 2222, 3333, 4444, 5555 ) 1205.22:47:09.5550000
//TimeSpan (Int32, Int32, Int32) 将新的 TimeSpan 初始化为指定的小时数、分钟数和秒数。
//TimeSpan (Int32, Int32, Int32, Int32) 将新的 TimeSpan 初始化为指定的天数、小时数、分钟数和秒数。
//TimeSpan (Int32, Int32, Int32, Int32, Int32) 将新的 TimeSpan 初始化为指定的天数、小时数、分钟数、秒数
和毫秒数。
//ASP.NET 中,两个时间相减,得到一个 TimeSpan 实例,TimeSpan 有一些属性:Days、TotalDays、Hours、
TotalHours、Minutes、TotalMinutes、Seconds、TotalSeconds、Ticks,注意没有 TotalTicks。
//这些属性名称开始理解有些困难,但阅读本文后,相应您一定茅塞顿开。
//举例说明
//•时间 1 是 2010-1-2 8:43:35;
//•时间 2 是 2010-1-12 8:43:34。
//用时间 2 减时间 1,得到一个 TimeSpan 实例。
//那么时间 2 比时间 1 多 9 天 23 小时 59 分 59 秒。
//那么,Days 就是 9,Hours 就是 23,Minutes 就是 59,Seconds 就是 59。
//再来看 Ticks,Tick 是一个计时周期,表示一百纳秒,即一千万分之一秒,那么 Ticks 在这里表示总共相差多少个
时间周期,即:9 * 24 * 3600 * 10000000 + 23 * 3600 * 10000000 + 59 * 60 * 10000000 + 59 * 10000000 =
8639990000000。3600 是一小时的秒数。
//TotalDays 就是把 Ticks 换算成日数,即:8639990000000 / (10000000 * 24 * 3600) = 9.99998842592593。
//TotalHours 就是把 Ticks 换算成小时数,即:8639990000000 / (10000000 * 3600) = 239.999722222222。
//TotalMinutes 就是把 Ticks 换算成分钟数,即:8639990000000 / (10000000 * 60) = 14399.9833333333。
//TotalSeconds 就是把 Ticks 换算成秒数,即:8639990000000 / (10000000) = 863999。
//负数
//上面是较晚的日期减较早的日期,所以各属性值为正数,如果是较早的日期减较晚的日期,则属性值为负数。
TimeSpan(
int
days,
int
hours,
int
minutes,
int
seconds
)
//求离最近发表时间的函数
public
string
DateStringFromNow(
DateTime
dt)
{
TimeSpan
span =
DateTime
.Now - dt;
if
(span.TotalDays > 60)
{
return
dt.ToShortDateString();
}
else
if
( span.TotalDays > 30 )
{
return
"1个月前"
;
}
else
if
(span.TotalDays > 14)
{
return
"2周前"
;
}
else
if
(span.TotalDays > 7)
{
return
"1周前"
;
}
else
if
(span.TotalDays > 1)
{
return
string
.Format(
"{0}天前"
, (
int
)
Math
.Floor(span.TotalDays));
}
else
if
(span.TotalHours > 1)
{
return
string
.Format(
"{0}小时前"
, (
int
)
Math
.Floor(span.TotalHours));
}
else
if
(span.TotalMinutes > 1)
{
return
string
.Format(
"{0}分钟前"
, (
int
)
Math
.Floor(span.TotalMinutes));
}
else
if
(span.TotalSeconds >= 1)
{
return
string
.Format(
"{0}秒前"
, (
int
)
Math
.Floor(span.TotalSeconds));
}
else
{
return
"1秒前"
;
}
}
//C#中使用TimeSpan计算两个时间的差值
//可以反加两个日期之间任何一个时间单位。
private
string
DateDiff(
DateTime
DateTime1,
DateTime
DateTime2)
{
string
dateDiff =
null
;
TimeSpan
ts1 =
new
TimeSpan
(DateTime1.Ticks);
TimeSpan
ts2 =
new
TimeSpan
(DateTime2.Ticks);
TimeSpan
ts = ts1.Subtract(ts2).Duration();
dateDiff = ts.Days.ToString()+
"天"
+ ts.Hours.ToString()+
"小时"
+ ts.Minutes.ToString()+
"分钟"
+ ts.Seconds.ToString()+
"秒"
;
return
dateDiff;
}
TimeSpan
ts = Date1 - Date2;
double
dDays = ts.TotalDays;
//带小数的天数,比如1天12小时结果就是1.5
int
nDays = ts.Days;
//整数天数,1天12小时或者1天20小时结果都是1
//说明:
//1.DateTime值类型代表了一个从公元0001年1月1日0点0分0秒到公元9999年12月31日23点59分59秒之间的具体日期时
刻。因此,你可以用DateTime值类型来描述任何在想象范围之内的时间。一个DateTime值代表了一个具体的时刻
//2.TimeSpan值包含了许多属性与方法,用于访问或处理一个TimeSpan值
//下面的列表涵盖了其中的一部分:
//Add:与另一个TimeSpan值相加。
//Days:返回用天数计算的TimeSpan值。
//Duration:获取TimeSpan的绝对值。
//Hours:返回用小时计算的TimeSpan值
//Milliseconds:返回用毫秒计算的TimeSpan值。
//Minutes:返回用分钟计算的TimeSpan值。
//Negate:返回当前实例的相反数。
//Seconds:返回用秒计算的TimeSpan值。
//Subtract:从中减去另一个TimeSpan值。
//Ticks:返回TimeSpan值的tick数。
//TotalDays:返回TimeSpan值表示的天数。
//TotalHours:返回TimeSpan值表示的小时数。
//TotalMilliseconds:返回TimeSpan值表示的毫秒数。
//TotalMinutes:返回TimeSpan值表示的分钟数。
//TotalSeconds:返回TimeSpan值表示的秒数。
///
<summary>
///
日期比较
///
</summary>
///
<param name="today">
当前日期
</param>
///
<param name="writeDate">
输入日期
</param>
///
<param name="n">
比较天数
</param>
///
<returns>
大于天数返回true,小于返回false
</returns>
private
bool
CompareDate(
string
today,
string
writeDate,
int
n)
{
DateTime
Today =
Convert
.ToDateTime(today);
DateTime
WriteDate =
Convert
.ToDateTime(writeDate);
WriteDate = WriteDate.AddDays(n);
if
(Today >= WriteDate)
return
false
;
else
return
true
;
}
//示例代码:
<
table
width
="100%"
border
="1"
cellspacing
="0"
cellpadding
="0">
<
tr
>
<
td
>
TimeSpan('T','2002-10-1','2002-1-1')
</
td
>
<
td
>
<!-- NoahValue ValueName="TimeSpan('T','2002-10-1','2002-1-1')" -->
</
td
>
</
tr
>
<
tr
>
<
td
>
TimeSpan('d','2002-10-1','2002-1-1')
</
td
>
<
td
>
<!-- NoahValue ValueName="TimeSpan('d','2002-10-1','2002-1-1')" -->
</
td
>
</
tr
>
<
tr
>
<
td
>
TimeSpan('h','2002-10-1','2002-1-1')
</
td
>
<
td
>
<!-- NoahValue ValueName="TimeSpan('h','2002-10-1','2002-1-1')" -->
</
td
>
</
tr
>
<
tr
>
<
td
>
TimeSpan('u','2002-10-1','2002-1-1')
</
td
>
<
td
>
<!-- NoahValue ValueName="TimeSpan('u','2002-10-1','2002-1-1')" -->
</
td
>
</
tr
>
<
tr
>
<
td
>
TimeSpan('m','2002-10-1','2002-1-1')
</
td
>
<
td
>
<!-- NoahValue ValueName="TimeSpan('m','2002-10-1','2002-1-1')" -->
</
td
>
</
tr
>
<
tr
>
<
td
>
TimeSpan('s','2002-10-1','2002-1-1')
</
td
>
<
td
>
<!-- NoahValue ValueName="TimeSpan('s','2002-10-1','2002-1-1')" -->
</
td
>
</
tr
>
<
tr
>
<
td
>
TimeSpan('D','2002-10-1','2002-1-1')
</
td
>
//在定义Date数据类型时候,必须注意下面三点:
//1. Date数值必须以数字符号"#"括起来。
//2. Date数值中的日期数据可有可无,如果有必须符合格式"m/d/yyyy"。
//3. Date数值中的时间数据可有可无,如果有必须和日期数据通过空格分开,并且时分秒之间以":"分开。
//一.DateTime和TimeSpan的关系和区别:
//DateTime和TimeSpan是Visual Basic .Net中用以处理时间日期类型数据的二个主要的结构,这二者的区别在于,
DatTime表示一个固定的时间,而TimeSpan表示的是一个时间间隔, 即一段时间。在下面介绍的程序示例中,TimeSpan就用以当
前时间和给定时间之差。
//二.DateTime和TimeSpan中的常用成员及其说明:
//DateTime结构和TimeSpan结构提供了丰富的方法和属性,通过这些方法和属性,几乎可以直接处理任何时间日期类型
数据。表01和表02分别是DateTime结构的常用属性和常用方法及其说明:
//属性 说明
//Date 获取此实例的日期部分。
//Day 获取此实例所表示的日期为该月中的第几天。
//DayOfWeek 获取此实例所表示的日期是星期几。
//DayOfYear 获取此实例所表示的日期是该年中的第几天。
//Hour 获取此实例所表示日期的小时部分。
//Millisecond 获取此实例所表示日期的毫秒部分。
//Minute 获取此实例所表示日期的分钟部分。
//Month 获取此实例所表示日期的月份部分。
//Now 创建一个DateTime实例,它是此计算机上的当前本地日期和时间。
//Second 获取此实例所表示日期的秒部分。
//TimeOfDay 获取此实例的当天的时间。
//Today 获取当前日期。
//Year 获取此实例所表示日期的年份部分。
//表01:DateTime类的常用属性及其说明
//方法 说明
//Add 将指定的TimeSpan的值加到此实例的值上。
//AddDays 将指定的天数加到此实例的值上。
//AddHours 将指定的小时数加到此实例的值上。
//AddMilliseconds 将指定的毫秒数加到此实例的值上。
//AddMinutes 将指定的分钟数加到此实例的值上。
//AddMonths 将指定的月份数加到此实例的值上。
//AddSeconds 将指定的秒数加到此实例的值上。
//AddYears 将指定的年份数加到此实例的值上。
//DaysInMonth 返回指定年份中指定月份的天数。
//IsLeapYear 返回指定的年份是否为闰年的指示。
//Parse 将日期和时间的指定字符串表示转换成其等效的DateTime实例。
//Subtract 从此实例中减去指定的时间或持续时间。
//ToLongDateString 将此实例的值转换为其等效的长日期字符串表示形式。
//ToLongTimeString 将此实例的值转换为其等效的长时间字符串表示形式。
//ToShortTimeString 将此实例的值转换为其等效的短时间字符串表示形式。
//ToShortDateString 将此实例的值转换为其等效的短日期字符串表示形式。
//表02:DateTime结构的常用方法及其说明
//表03和表04分别是TimeSpan结构的常用属性和常用方法及其说明:
//属性 说明
//Days 获取由此实例表示的整天数。
//Hours 获取由此实例表示的整小时数。
//Milliseconds 获取由此实例表示的整毫秒数。
//Minutes 获取由此实例表示的整分钟数。
//Seconds 获取由此实例表示的整秒数。
//Ticks 获取用刻度表示的此实例的值。
//TotalDays 获取以整天数和天的小数部分表示的此实例的值。
//TotalHours 获取以整小时数和小时的小数部分表示的此实例的值。
//TotalMilliseconds 获取以整毫秒数和毫秒的小数部分表示的此实例的值。
//TotalMinutes 获取以整分钟数和分钟的小数部分表示的此实例的值。
//TotalSeconds 获取以整秒数和秒的小数部分表示的此实例的值。
//表03:TimeSpan结构的常用属性及其说明
//方法 说明
//Add 将指定的TimeSpan添加到此实例中。
//Duration 返回其值为此实例的绝对值的TimeSpan。
//FromDays 返回表示指定天数的TimeSpan,其中对天数的指定精确到最接近的毫秒。
//FromHours 返回表示指定小时数的TimeSpan,其中对小时数的指定精确到最接近的毫秒。
//FromMilliseconds 返回表示指定毫秒数的TimeSpan。
//FromMinutes 返回表示指定分钟数的TimeSpan,其中对分钟数的指定精确到最接近的毫秒。
//FromSeconds 返回表示指定秒数的TimeSpan,其中对秒数的指定精确到最接近的毫秒。
//Subtract 从此实例中减去指定的TimeSpan。
//表04:TimeSpan结构的常用方法及其说明