您的位置:首页 > 编程语言 > C#

C# 根据当前时间获取,本周,本月,本季度等时间段 .Net中Exception

2011-09-05 17:49 603 查看
DateTimedt
=DateTime.Now;//当前时间

DateTimestartWeek=dt.AddDays(1
-Convert.ToInt32(dt.DayOfWeek.ToString("d")));//本周周一

DateTimeendWeek
=startWeek.AddDays(6);//本周周日

DateTimestartMonth=dt.AddDays(1
-dt.Day);//本月月初

DateTimeendMonth
=startMonth.AddMonths(1).AddDays(-1);//本月月末

//DateTimeendMonth=startMonth.AddDays((dt.AddMonths(1)-dt).Days-1);//本月月末

DateTimestartQuarter=dt.AddMonths(0
-(dt.Month
-1)
%3).AddDays(1
-dt.Day);//本季度初

DateTimeendQuarter
=startQuarter.AddMonths(3).AddDays(-1);//本季度末

DateTimestartYear=
newDateTime(dt.Year,1,1);//本年年初

DateTimeendYear
=newDateTime(dt.Year,12,31);//本年年末

至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。

C#中datetime的使用

//如果你还不明白,再看一下中文显示星期几的方法就应该懂了

//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的

string[]Day
=new
string[]{"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
stringweek
=Day[Convert.ToInt32(DateTime.Now.DayOfWeek.ToString("d"))].ToString();//上周,同理,一个周是7天,上周就是本周再减去7天,下周也是一样

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7);//上周一

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7).AddDays(6);//上周末(星期日)

//下周

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7);//下周一

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7).AddDays(6);//下周末

//本月,很多人都会说本月的第一天嘛肯定是1号,最后一天就是下个月一号再减一天。当然这是对的

//一般的写法

DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1";//第一天

DateTime.Parse(DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天

//巧用C#里ToString的字符格式化更简便

DateTime.Now.ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();//上个月,减去一个月份

DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下个月,加去一个月份

DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();//7天后

DateTime.Now.Date.ToShortDateString();DateTime.Now.AddDays(7).ToShortDateString();//7天前

DateTime.Now.AddDays(-7).ToShortDateString();DateTime.Now.Date.ToShortDateString();//本年度,用ToString的字符格式化我们也很容易地算出本年度的第一天和最后一天

DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();//上年度,不用再解释了吧

DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();//下年度

DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();//本季度,很多人都会觉得这里难点,需要写个长长的过程来判断。其实不用的,我们都知道一年四个季度,一个季度三个月

//首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了

DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day);//同理,本季度的最后一天就是下季度的第一天减一

DateTime.Parse(DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下季度,相信你们都知道了。。。。收工

DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.AddMonths(6
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//上季度

DateTime.Now.AddMonths(-3
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now);DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day).AddDays(-1).ToShortDateString();DateTimedt
=DateTime.Now;//当前时间

DateTimestartWeek=dt.AddDays(1
-Convert.ToInt32(dt.DayOfWeek.ToString("d")));//本周周一

DateTimeendWeek
=startWeek.AddDays(6);//本周周日

DateTimestartMonth=dt.AddDays(1
-dt.Day);//本月月初

DateTimeendMonth
=startMonth.AddMonths(1).AddDays(-1);//本月月末

//DateTimeendMonth=startMonth.AddDays((dt.AddMonths(1)-dt).Days-1);//本月月末

DateTimestartQuarter=dt.AddMonths(0
-(dt.Month
-1)
%3).AddDays(1
-dt.Day);//本季度初

DateTimeendQuarter
=startQuarter.AddMonths(3).AddDays(-1);//本季度末

DateTimestartYear=
newDateTime(dt.Year,1,1);//本年年初

DateTimeendYear
=newDateTime(dt.Year,12,31);//本年年末

至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。

C#中datetime的使用

//如果你还不明白,再看一下中文显示星期几的方法就应该懂了

//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的

string[]Day
=new
string[]{"星期日","星期一","星期二","星期三","星期四","星期五","星期六"};
stringweek
=Day[Convert.ToInt32(DateTime.Now.DayOfWeek.ToString("d"))].ToString();//上周,同理,一个周是7天,上周就是本周再减去7天,下周也是一样

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7);//上周一

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))-7).AddDays(6);//上周末(星期日)

//下周

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7);//下周一

DateTime.Now.AddDays(Convert.ToInt32(1
-Convert.ToInt32(DateTime.Now.DayOfWeek))+7).AddDays(6);//下周末

//本月,很多人都会说本月的第一天嘛肯定是1号,最后一天就是下个月一号再减一天。当然这是对的

//一般的写法

DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1";//第一天

DateTime.Parse(DateTime.Now.Year.ToString()
+DateTime.Now.Month.ToString()
+"1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天

//巧用C#里ToString的字符格式化更简便

DateTime.Now.ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();//上个月,减去一个月份

DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下个月,加去一个月份

DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();//7天后

DateTime.Now.Date.ToShortDateString();DateTime.Now.AddDays(7).ToShortDateString();//7天前

DateTime.Now.AddDays(-7).ToShortDateString();DateTime.Now.Date.ToShortDateString();//本年度,用ToString的字符格式化我们也很容易地算出本年度的第一天和最后一天

DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();//上年度,不用再解释了吧

DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();//下年度

DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();//本季度,很多人都会觉得这里难点,需要写个长长的过程来判断。其实不用的,我们都知道一年四个季度,一个季度三个月

//首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了

DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day);//同理,本季度的最后一天就是下季度的第一天减一

DateTime.Parse(DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//下季度,相信你们都知道了。。。。收工

DateTime.Now.AddMonths(3
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01");DateTime.Parse(DateTime.Now.AddMonths(6
-((DateTime.Now.Month
-1)
%3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();//上季度

DateTime.Now.AddMonths(-3
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now);DateTime.Now.AddMonths(0
-((DateTime.Now.Month
-1)
%3)).AddDays(1
-DateTime.Now.Day).AddDays(-1).ToShortDateString();这篇文章旨在与园友分享我对Exception的理解,如果存在不足的地方欢迎您指出。

前不久写过一篇MVC的Exception的文章,这回重点讲解在实际开发中我对Exception的认识。

讲到Exception难免会涉及到经典的代码try..catch...finally..至于一些基本概念:这个代码块的执行方式、多catch的异常捕获顺序、exception的继承。这些不是本篇讨论的重点,但这不并代表基本概念不重要。(:

建立Exception时建议日常开发中需要注意以下几点:

一、Thrownewexception

曾经看过有人在简单的函数内疯狂的使用thrownew参与业务逻辑。比如,以下代码:

01
public
object
DoSomeThing(
string

userName)
02
{
03
try
04
{
05
if

(String.IsNullOrEmpty(userName))
06
{
07
throw

new
Exception(
"用户名不能为空"
);
08
}
09
}
10
catch

(Exceptionex)
11
{
12
return

ex.Message;
13
}
14
return

true
;
15
}
逻辑类似以上代码,就是一个单一的函数,每当我看到这样的单一函数,总是觉得很奇怪。或许是自身水平有限,似乎难以理解为了catch住一个exception对象需要那么大费周章的去thrownew么?个人认为如果某方法内嵌套的方法根据业务逻辑主动抛出异常,让外层方法截获到这个异常,此时被嵌套的方法方可使用thrownew....

二、抛出不该抛出的Exception

上文中的DoSomeThing函数如果在catch时不进一步封装,直接把Excepiton抛到UI层,又或者直接显示给客户。如果异常堆栈中提示某些敏感数据。比如SQL查询语句、WebService

URI或POST信息等。这些敏感信息应该永远不让客户知道,暴露出这些信息有可能对系统造成潜在安全隐患!

三、更好的利用Exception

在实际的开发中,既然抛出了Exception那么我们应该为Exception提供尽可能多的关于异常本身的有用信息。如何为抛出的异常提供更多的有用信息呢?请看以下代码:

01
public
static
void

ExecuteCommand(Action<IDbCommand>action,
ref

string
errMsg)

02
{
03
using

(varconnection=
new

SqlConnection(
"数据库连接字符串"
))
04
{
05
varcmd=connection.CreateCommand();
06
try
07
{
08
action(cmd);
09
cmd.ExecuteNonQuery();
10
}
11
catch

(DbExceptionex)
//注意这里将DbExceptioncatch住
12
{
13
errMsg=ex.Message;
14
varparameters=
new
Dictionary<
string
,
object
>();

15
foreach

(SqlParameterp
in

cmd.Parameters)
16
parameters.Add(p.ParameterName,p.Value);
17
18
//尽可能获取与exception相关的有用信息,这里只是用SqlParameter举例而已。
19
20
//TODO:(将parameters与ex对象保存或者进一步处理)
21
22
}
23
catch

(Exceptionex)
24
{
25
//TODO其他的异常处理
26
}
27
finally
28
{
29
cmd.Dispose();
30
}
31
}
32
}
注释已经给的很清晰了,目的就是尽可能的提供与异常相关的有用信息,方便日后异常出现时便于调试。

ExecuteCommand方法调用如下:

01
static
void
Main(
string
[]args)
02
{
03
string

errMsg=
string
.Empty;
04
ExecuteCommand(cmd=>
05
{
06
cmd.CommandText=
"UPDATEuserSETname=@nameWHEREid=@id"
;
07
cmd.Parameters.Add(
new

SqlParameter(
"name"
,
"字符串参数值"
));

08
cmd.Parameters.Add(
new

SqlParameter(
"id"
,1));
09
},
ref
errMsg);
10
11
}
类似以上机制,如果异常出现了,我认为可以大大减少debug的时间。

最后希望本篇文章可以给您带来帮助,如有不足之处欢迎指出,谢谢!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐