C# 常用操作
2013-02-28 11:11 Mike.Jiang 阅读(1498) 评论(0) 编辑 收藏 举报1,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#常日期转换(转)
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, 测试数据库连接时间差(转)
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; }
解决方法是:给文本框加上样式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); }
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