• C# 常用操作


    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
  • 相关阅读:
    asp.net mvc 从数据库中读取图片
    给折腾ramdisk的朋友们一点建议
    docker安装Jenkins和构建python容器
    docker笔记
    接口加密方式
    Dockerfile常用命令
    北斗七星小队团队展示
    固件程序设计实验内容1.4
    Myod实验 20181328祝维卿
    电子公文系统团队作业(四):描述设计
  • 原文地址:https://www.cnblogs.com/dataadapter/p/2914181.html
Copyright © 2020-2023  润新知