代码改变世界

C# 常用操作

2013-02-28 11:11  Mike.Jiang  阅读(1498)  评论(0编辑  收藏  举报

1,VS2010 修改模板文件,增加默认注释

通过修改模板文件,为代码文件添加默认的注释,如创建人、时间和版本等信息。

链接:VS2010 修改模板文件,增加默认注释

2, ASP.NET 页面生命周期

来源于MSDN: ASP.NET Page Life Cycle

3, Repeater绑定值时应该是单引在外面,双引在里面,否则会报“字符文本中的字符太多”的错误

<tr class='<%# Eval("EntryName") %>'>

<a href='#' onclick="NameLink('<%#Eval("F_FriendUID")%>')"></a>

4, C#DateTime的默认值问题

C#DateTime不能为空,默认值为0001-01-01 00:00:00,但SQL SERVER中日期最小值是1900-01-01 00:00:00。这样会有两个问题:

  • 当数据库中日期字段为NULL时,赋值到实体上会有一个默认值,最终显示到页面上。
  • 当数据库中日期字段为NULL时,赋值到实体上,然后不改变日期的值,再更新回数据库就会报错。

解决方法是:使用DateTime?,即可空的日期类型。

5,c#常日期转换(转)

View Code
DateTime dt = DateTime.Now;
Label1.Text = dt.ToString();//2005-11-5 13:21:25
Label2.Text = dt.ToFileTime().ToString();//127756416859912816
Label3.Text = dt.ToFileTimeUtc().ToString();//127756704859912816
Label4.Text = dt.ToLocalTime().ToString();//2005-11-5 21:21:25
Label5.Text = dt.ToLongDateString().ToString();//2005年11月5日
Label6.Text = dt.ToLongTimeString().ToString();//13:21:25
Label7.Text = dt.ToOADate().ToString();//38661.5565508218
Label8.Text = dt.ToShortDateString().ToString();//2005-11-5
Label9.Text = dt.ToShortTimeString().ToString();//13:21
Label10.Text = dt.ToUniversalTime().ToString();//2005-11-5 5:21:25
?2005-11-5 13:30:28.4412864
Label1.Text = dt.Year.ToString();//2005
Label2.Text = dt.Date.ToString();//2005-11-5 0:00:00
Label3.Text = dt.DayOfWeek.ToString();//Saturday
Label4.Text = dt.DayOfYear.ToString();//309
Label5.Text = dt.Hour.ToString();//13
Label6.Text = dt.Millisecond.ToString();//441
Label7.Text = dt.Minute.ToString();//30
Label8.Text = dt.Month.ToString();//11
Label9.Text = dt.Second.ToString();//28
Label10.Text = dt.Ticks.ToString();//632667942284412864
Label11.Text = dt.TimeOfDay.ToString();//13:30:28.4412864
Label1.Text = dt.ToString();//2005-11-5 13:47:04
Label2.Text = dt.AddYears(1).ToString();//2006-11-5 13:47:04
Label3.Text = dt.AddDays(1.1).ToString();//2005-11-6 16:11:04
Label4.Text = dt.AddHours(1.1).ToString();//2005-11-5 14:53:04
Label5.Text = dt.AddMilliseconds(1.1).ToString();//2005-11-5 13:47:04
Label6.Text = dt.AddMonths(1).ToString();//2005-12-5 13:47:04
Label7.Text = dt.AddSeconds(1.1).ToString();//2005-11-5 13:47:05
Label8.Text = dt.AddMinutes(1.1).ToString();//2005-11-5 13:48:10
Label9.Text = dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
Label10.Text = dt.CompareTo(dt).ToString();//0
//Label11.Text = dt.Add(?).ToString();//问号为一个时间段
Label1.Text = dt.Equals("2005-11-6 16:11:04").ToString();//False
Label2.Text = dt.Equals(dt).ToString();//True
Label3.Text = dt.GetHashCode().ToString();//1474088234
Label4.Text = dt.GetType().ToString();//System.DateTime
Label5.Text = dt.GetTypeCode().ToString();//DateTime
Label1.Text = dt.GetDateTimeFormats('s')[0].ToString();//2005-11-05T14:06:25
Label2.Text = dt.GetDateTimeFormats('t')[0].ToString();//14:06
Label3.Text = dt.GetDateTimeFormats('y')[0].ToString();//2005年11月
Label4.Text = dt.GetDateTimeFormats('D')[0].ToString();//2005年11月5日
Label5.Text = dt.GetDateTimeFormats('D')[1].ToString();//2005 11 05
Label6.Text = dt.GetDateTimeFormats('D')[2].ToString();//星期六 2005 11 05
Label7.Text = dt.GetDateTimeFormats('D')[3].ToString();//星期六 2005年11月5日
Label8.Text = dt.GetDateTimeFormats('M')[0].ToString();//11月5日
Label9.Text = dt.GetDateTimeFormats('f')[0].ToString();//2005年11月5日 14:06
Label10.Text = dt.GetDateTimeFormats('g')[0].ToString();//2005-11-5 14:06
Label11.Text = dt.GetDateTimeFormats('r')[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT
Label1.Text =? string.Format("{0:d}",dt);//2005-11-5
Label2.Text =? string.Format("{0:D}",dt);//2005年11月5日
Label3.Text =? string.Format("{0:f}",dt);//2005年11月5日 14:23
Label4.Text =? string.Format("{0:F}",dt);//2005年11月5日 14:23:23
Label5.Text =? string.Format("{0:g}",dt);//2005-11-5 14:23
Label6.Text =? string.Format("{0:G}",dt);//2005-11-5 14:23:23
Label7.Text =? string.Format("{0:M}",dt);//11月5日
Label8.Text =? string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
Label9.Text =? string.Format("{0:s}",dt);//2005-11-05T14:23:23
Label10.Text = string.Format("{0:t}",dt);//14:23
Label11.Text = string.Format("{0:T}",dt);//14:23:23
Label12.Text = string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
Label13.Text = string.Format("{0:U}",dt);//2005年11月5日 6:23:23
Label14.Text = string.Format("{0:Y}",dt);//2005年11月
Label15.Text = string.Format("{0}",dt);//2005-11-5 14:23:23?
Label16.Text = string.Format("{0:yyyyMMddHHmmssffff}",dt);
//yyyymm等可以设置,比如Label16.Text = string.Format("{0:yyyyMMdd}",dt);    

6,List和Dictionary对象的转换

Dictionary 转 List:Dictionary<string,string> d=new Dictionary<string,string>(); var l=d.ToList();

List 转Dictionary:List<Model> l=new List<Model>(); l.ToDictionary(x=>x.ID,x=>x.Name);//注Model是指实体类,假定有ID和Name的属性。

 7, NUnit测试

NUnit详细使用方法

 

 8, 测试数据库连接时间差(转)

View Code
 static void Main(string[] args)
        {
            string connectionstring = "Data Source=;Initial Catalog=;Persist Security Info=True;User ID=;Password=;";
            SqlConnection conn = new SqlConnection(connectionstring);
            DateTime time = DateTime.Now;
            Console.WriteLine(time);
            conn.Open();
            Console.WriteLine(GetTimeSpan(time, DateTime.Now));
            conn.Close();
            conn.Dispose();

            conn = new SqlConnection(connectionstring);
            time = DateTime.Now;
            conn.Open();
            Console.WriteLine(GetTimeSpan(time, DateTime.Now));
            conn.Close();
            conn.Dispose();
            Console.Read();
        }
    
        private static int GetTimeSpan(DateTime dtStart,DateTime dtEnd)
        {
            TimeSpan ts1 = new TimeSpan(dtStart.Ticks);
            TimeSpan ts2 = new TimeSpan(dtEnd.Ticks);    
            TimeSpan ts = ts2.Subtract(ts1).Duration();
            return ts.Milliseconds;
        }

 9, c#项目编译生成示例

xcopy "$(SolutionDir)DAL\Maps" "$(SolutionDir)BTSWeb\Maps"  /s /e /y

 10,Visual Studio常用快捷键

所有代码折叠:CTRL+M+O

VS最大化:SHIFT+CTRL+ENTER

格式化:CTRL+K+D

11,ASP.NET后台代码无法获取ReadOnly文本框的值

input.disabled, textarea.disabled
{
    border-color: #9eabb3 #d5dbdf #d5dbdf #9eabb3;
    background-color: #F6F6F6;
}
View Code

解决方法是:给文本框加上样式CssClass="disabled",然后在公共的js文件中写上$("input.disabled").attr("onfocus", "this.blur();");,即当文本框获得到焦点时立刻再离开文本框,并且背景改成灰色。

12,在c#中,将josn字符串序列化成对象或对象集合

在WEB应用,尤其是AJAX应用中,有时需要将复杂的对象传到服务端处理。这里,我们可以在前台将数据组织成JSON格式,然后在服务端序列化成对象(前段时间找的,忘记出处了)。

public class OrderBy 
        {
            public string SortCriterion { set; get; }

            public string SortDirection { set; get; }
        }

JavaScriptSerializer jsSerializer = new JavaScriptSerializer();

            string jsonStringSingle = "{'SortCriterion': 'TXN', 'SortDirection':'DESC'}".Replace("'", "\"");
            var entity = jsSerializer.Deserialize<OrderBy>(jsonStringSingle);

            string jsonStringCollection = "[{'SortCriterion': 'TXN', 'SortDirection':'DESC'},{'SortCriterion': 'TRANSDATE', 'SortDirection':'ASC'}]".Replace("'", "\"");
            if (!string.IsNullOrEmpty(jsonStringCollection))
            {
                var collection = jsSerializer.Deserialize<IEnumerable<OrderBy>>(jsonStringCollection);
            }
View Code

 13, List排序

If you mean an in-place sort (i.e. the list is updated):

people.Sort((x, y)=>string.Compare(x.LastName, y.LastName));

If you mean a new list:

var newList = people.OrderBy(x=>x.LastName).ToList();// ToList optional