DateTime dt
= DateTime.Now;
//当前时间
DateTime startWeek = dt.AddDays(1
- Convert.ToInt32(dt.DayOfWeek.ToString("d")));
//本周周一
DateTime endWeek
= startWeek.AddDays(6);
//本周周日
DateTime startMonth = dt.AddDays(1
- dt.Day);
//本月月初
DateTime endMonth
= startMonth.AddMonths(1).AddDays(-1);
//本月月末
//DateTime endMonth = startMonth.AddDays((dt.AddMonths(1) - dt).Days - 1);
//本月月末
DateTime startQuarter = dt.AddMonths(0
- (dt.Month
- 1)
% 3).AddDays(1
- dt.Day);
//本季度初
DateTime endQuarter
= startQuarter.AddMonths(3).AddDays(-1);
//本季度末
DateTime startYear =
new DateTime(dt.Year,
1, 1);
//本年年初
DateTime endYear
= new DateTime(dt.Year,
12,
31); //本年年末
至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。
C#中datetime的使用
//如果你还不明白,再看一下中文显示星期几的方法就应该懂了
//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的
string[] Day
= new
string[] {
"星期日",
"星期一",
"星期二",
"星期三",
"星期四",
"星期五",
"星期六" };
string week
= 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();
DateTime dt
= DateTime.Now;
//当前时间
DateTime startWeek = dt.AddDays(1
- Convert.ToInt32(dt.DayOfWeek.ToString("d")));
//本周周一
DateTime endWeek
= startWeek.AddDays(6);
//本周周日
DateTime startMonth = dt.AddDays(1
- dt.Day);
//本月月初
DateTime endMonth
= startMonth.AddMonths(1).AddDays(-1);
//本月月末
//DateTime endMonth = startMonth.AddDays((dt.AddMonths(1) - dt).Days - 1);
//本月月末
DateTime startQuarter = dt.AddMonths(0
- (dt.Month
- 1)
% 3).AddDays(1
- dt.Day);
//本季度初
DateTime endQuarter
= startQuarter.AddMonths(3).AddDays(-1);
//本季度末
DateTime startYear =
new DateTime(dt.Year,
1, 1);
//本年年初
DateTime endYear
= new DateTime(dt.Year,
12,
31); //本年年末
至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。
C#中datetime的使用
//如果你还不明白,再看一下中文显示星期几的方法就应该懂了
//由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的
string[] Day
= new
string[] {
"星期日",
"星期一",
"星期二",
"星期三",
"星期四",
"星期五",
"星期六" };
string week
= 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 时建议日常开发中需要注意以下几点:
一、Throw new exception
曾经看过有人在简单的函数内疯狂的使用throw new 参与业务逻辑。比如,以下代码:
01 |
public
object DoSomeThing( string
userName) |
05 |
if
(String.IsNullOrEmpty(userName)) |
07 |
throw
new Exception( "用户名不能为空" );
|
逻辑类似以上代码,就是一个单一的函数,每当我看到这样的单一函数,总是觉得很奇怪。或许是自身水平有限,似乎难以理解为了catch住一个exception对象需要那么大费周章的去throw new 么?个人认为如果某方法内嵌套的方法根据业务逻辑主动抛出异常,让外层方法截获到这个异常,此时被嵌套的方法方可使用throw new ....
二、抛出不该抛出的Exception
上文中的DoSomeThing函数如果在catch时不进一步封装,直接把Excepiton抛到UI层,又或者直接显示给客户。如果异常堆栈中提示某些敏感数据。比如SQL查询语句、WebService
URI或POST信息等。这些敏感信息应该永远不让客户知道,暴露出这些信息有可能对系统造成潜在安全隐患!
三、更好的利用Exception
在实际的开发中,既然抛出了Exception那么我们应该为Exception提供尽可能多的关于异常本身的有用信息。如何为抛出的异常提供更多的有用信息呢?请看以下代码:
01 |
public
static void
ExecuteCommand(Action<IDbCommand> action, ref
string errMsg)
|
03 |
using
(var connection = new
SqlConnection( "数据库连接字符串" ))
|
05 |
var cmd = connection.CreateCommand();
|
09 |
cmd.ExecuteNonQuery();
|
11 |
catch
(DbException ex) |
14 |
var parameters =
new Dictionary< string ,
object >();
|
15 |
foreach
(SqlParameter p in
cmd.Parameters) |
16 |
parameters.Add(p.ParameterName, p.Value);
|
注释已经给的很清晰了,目的就是尽可能的提供与异常相关的有用信息,方便日后异常出现时便于调试。
ExecuteCommand方法调用如下:
01 |
static
void Main( string [] args)
|
03 |
string
errMsg = string .Empty;
|
06 |
cmd.CommandText =
"UPDATE user SET name=@name WHERE id=@id" ;
|
07 |
cmd.Parameters.Add( new
SqlParameter( "name" ,
"字符串参数值" ));
|
08 |
cmd.Parameters.Add( new
SqlParameter( "id" , 1));
|
类似以上机制,如果异常出现了,我认为可以大大减少debug的时间。
最后希望本篇文章可以给您带来帮助,如有不足之处欢迎指出,谢谢!