苏州溥秋智能科技有限公司
请选择 进入手机版 | 继续访问电脑版

QQ登录

只需一步,快速开始

微信登录

扫一扫,访问微社区

查看: 5450|回复: 0

C#中Datetime类型数据如何加减日期?

[复制链接]
  • TA的每日心情
    奋斗
    2017-11-24 21:31
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    147

    主题

    78

    帖子

    753

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    753
    发表于 2019-9-28 09:29:28 | 显示全部楼层 |阅读模式
    第一种
    DateTime time1 =new DateTime(1982,4,24,14,23,06);
    DateTime time2 =new DateTime(1982,1,21,8,16,32);
    TimeSpan ts= time2.Subtract(time1);
    string timespan = "相差:"
    +ts.Days.ToString()+"天"
    +ts.Hours.ToString()+"小时"
    +ts.Minutes.ToString()+"分钟"
    +ts.Seconds.ToString()+"秒";
    第二种:
    DateTime dt1 = DateTime.Now;
    DateTime dt2 = DateTime.Now.AddDays(-7);
    TimeSpan ts = dt1 - dt2; //TimeSpan 是一个 时间差
    int days = ts.Days; //dt1和dt2相差多少天
    第三种 DateTime.Add系列
    System.DateTime today = System.DateTime.Now;
    System.TimeSpan duration = new System.TimeSpan(36, 0, 0, 0);
    System.DateTime answer = today.Add(duration);
    outputBlock.Text += String.Format("{0:dddd}", answer) + "\n";
    DateTime dt2 = DateTime.Now.AddDays(-7); 当前日期前7天
    DateTime dt2 = DateTime.Now.AddDays(7); 当前日期后7天
    其他如 DateTime.AddSeconds 等等,可参考 AddDays使用。

    C#对DateTime类型的操作总结:
    http://www.cnblogs.com/yqy542006/archive/2007/03/27/689448.html
    一、取某月的最后一天
    法一、使用算出该月多少天,年+月+加上多少天即得,举例取今天这个月的最后一天
    private void GetLastDateForMonth(DateTime DtStart,out DateTime DtEnd)
    {
    int Dtyear,DtMonth; DtStart = DateTime.Now;
    Dtyear = DtStart.Year;
    DtMonth = DtStart.Month; int MonthCount = DateTime.DaysInMonth(Dtyear,DtMonth);
    DtEnd = Convert.ToDateTime(Dtyear.ToString()+"-"+DtMonth.ToString()+"-"+MonthCount); }
    法二、取出下月的第一天减去一天便是这个的最后一天
    private void GetLastDateForMonth(DateTime DtStart,out DateTime DtEnd)
    {
    int Dtyear,DtMonth; DtStart = DateTime.Now.AddMonths(1);
    Dtyear = DtStart.Year;
    DtMonth = DtStart.Month;
    DtEnd = Convert.ToDateTime(Dtyear.ToString()+"-"+DtMonth.ToString()+"-"+"1").AddDays(-1); } 二、时间差的计算
    法一、使用TimeSpan ,同时也介绍一下TimeSpan的用法
    相关属性和函数
    Add:与另一个TimeSpan值相加。
    Days:返回用天数计算的TimeSpan值。
    Duration:获取TimeSpan的绝对值。
    Hours:返回用小时计算的TimeSpan值
    Milliseconds:返回用毫秒计算的TimeSpan值。
    Minutes:返回用分钟计算的TimeSpan值。
    Negate:返回当前实例的相反数。
    Seconds:返回用秒计算的TimeSpan值。
    Subtract:从中减去另一个TimeSpan值。
    Ticks:返回TimeSpan值的tick数。
    TotalDays:返回TimeSpan值表示的天数。
    TotalHours:返回TimeSpan值表示的小时数。
    TotalMilliseconds:返回TimeSpan值表示的毫秒数。
    TotalMinutes:返回TimeSpan值表示的分钟数。
    TotalSeconds:返回TimeSpan值表示的秒数。
    简单示例:
    DateTime d1 =new DateTime(2004,1,1,15,36,05);
    DateTime d2 =new DateTime(2004,3,1,20,16,35);
    TimeSpan d3 = d2.Subtract(d1);
    LbTime.Text = "相差:"
    +d3.Days.ToString()+"天"
    +d3.Hours.ToString()+"小时"
    +d3.Minutes.ToString()+"分钟"
    +d3.Seconds.ToString()+"秒";
    法二、使用Sql中的DATEDIFF函数
    使用方法:DATEDIFF ( datepart , startdate , enddate )
    它能帮你取出你想要的各种形式的时间差,如相隔多少天,多少小时,多少分钟等,具体格式如下: 日期部分 缩写 year yy, yyyy quarter qq, q Month mm, m dayofyear dy, y Day dd, d Week wk, ww Hour hh minute mi, n second ss, s millisecond ms
    如:datediff(mi,DtOpTime,DtEnd) 便能取出他们之间时间差的分钟总数,已经帮你换算好了,对于要求规定单位,时、分、秒特别有用




    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    联系方式
    0512-67225095 周一至周日9:00 - 21:00
    公司地址:苏州工业园区仁爱路99号D602-40

    苏州溥秋智能科技有限公司2017年8月成立,专门为客户提供数字信息化和物联网化的产品和服务。

    Array  X3.4© 2013-2017 苏州溥秋智能科技有限公司

    Archiver|手机版|小黑屋|苏州溥秋智能科技有限公司 ( 苏ICP备18046360号-3 )

    GMT+8, 2020-8-12 23:11 , Processed in 0.082081 second(s), 21 queries .

    快速回复 返回顶部 返回列表