C#日期时间相关工具类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace util
{
    class DateTimeUtils
    {
        /// <summary>
        /// 根据当前年份和月份查询当月的所有日期集合
        /// </summary>
        /// <param name="year"></param>
        /// <param name="month"></param>
        /// <returns></returns>
        public List<DateTime> getAllDates(int year, int month)
        {
            var ret = new List<DateTime>();
            for (int i = 1; i <= DateTime.DaysInMonth(year, month); i++)
            {
                ret.Add(new DateTime(year, month, i));
            }
            return ret;
        }

        /// <summary>
        /// 判断一个日期是否在一个日期范围时间内
        /// </summary>
        /// <param name="dt">要判断的日期</param>
        /// <param name="dt1">开始日期</param>
        /// <param name="dt2">结束日期</param>
        /// <returns></returns>
        public static bool IsInDate(DateTime dt, DateTime dt1, DateTime dt2)
        {
            return dt.CompareTo(dt1) >= 0 && dt.CompareTo(dt2) <= 0;
        }

        /// <summary>
        /// 根据格式获取相关的时间差:天、时、分、秒
        /// </summary>
        /// <param name="dt1">旧的时间</param>
        /// <param name="dt2">新的时间</param>
        /// <returns></returns>
        public static string[] getDayHourBranchSecond(DateTime dt1, DateTime dt2)
        {
            string[] arr = new string[4];
            //计算两个日期的时间间隔
            TimeSpan ts1 = new TimeSpan(dt1.Ticks);
            TimeSpan ts2 = new TimeSpan(dt2.Ticks);
            TimeSpan ts = ts1.Subtract(ts2).Duration();
            /*var dateDiff = ts.Days.ToString() + " 天" + ts.Hours.ToString() + " 小时" + ts.Minutes.ToString() + " 分钟" + ts.Seconds.ToString() + " 秒";*/
            // "177 天15 小时16 分钟21 秒"
            arr[0] = ts.Days.ToString();
            arr[1] = ts.Hours.ToString();
            arr[2] = ts.Minutes.ToString();
            arr[3] = ts.Seconds.ToString();
            return arr;
        }

        /// <summary>
        /// 比较两个日期大小
        /// 日期一是否大于日期二
        /// </summary>
        /// <param name="dateStr1">日期1</param>
        /// <param name="dateStr2">日期2</param>
        public static bool CompanyDate(DateTime dateStr1, DateTime dateStr2)
        {
            // 将日期字符串转换为日期对象
            int compNum = DateTime.Compare(dateStr1, dateStr2);

            // dateStr1> dateStr2
            if (compNum > 0)
            {
                return true;
            }
            // dateStr1= dateStr2
            if (compNum == 0)
            {
                return true;
            }
            // dateStr1< dateStr2
            if (compNum < 0)
            {
                return false;
            }
            return false;
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
参数format格式详细用法  格式字符 关联属性/说明  d ShortDatePattern  D LongDatePattern  f 完整日期时间(长日期和短时间)  F FullDateTimePattern(长日期和长时间)  g 常规(短日期和短时间)  G 常规(短日期和长时间)  m、M MonthDayPattern  r、R RFC1123Pattern  s 使用当地时间的 SortableDateTimePattern(基于ISO8601)  t ShortTimePattern  T LongTimePattern  u UniversalSortableDateTimePattern 用于显示通用时间的格式  U 使用通用时间的完整日期时间(长日期和长时间)  y、Y YearMonthPattern  C# 日期格式转换  下表列出了可被合并以构造自定义模式的模式。这些模式是区分大小写的;例如,识别“MM”,但不识别“mm”。如果自定义模式包含空白字符或用单引号括起来的字符,则输出字符串页也将包含这些字符。未定义为格式模式的一部分或未定义为格式字符的字符按其原义复制。    格式模式 说明  d 月中的某一天。一位数的日期没有前导零。  dd 月中的某一天。一位数的日期有一个前导零。  ddd 周中某天的缩写名称,在 AbbreviatedDayNames 中定义。  dddd 周中某天的完整名称,在 DayNames 中定义。  M 月份数字。一位数的月份没有前导零。  MM 月份数字。一位数的月份有一个前导零。  MMM 月份的缩写名称,在 AbbreviatedMonthNames 中定义。  MMMM 月份的完整名称,在 MonthNames 中定义。  y 不包含纪元的年份。如果不包含纪元的年份小于 10,则显示不具有前导零的年份。  yy 不包含纪元的年份。如果不包含纪元的年份小于 10,则显示具有前导零的年份。  yyyy 包括纪元的四位数的年份。  gg 时期或纪元。如果要设置格式的日期不具有关联的时期或纪元字符串,则忽略该模式。  h 12 小时制的小时。一位数的小时数没有前导零。  hh 12 小时制的小时。一位数的小时数有前导零。  H 24 小时制的小时。一位数的小时数没有前导零。  HH 24 小时制的小时。一位数的小时数有前导零。  m 分钟。一位数的分钟数没有前导零。  mm 分钟。一位数的分钟数有一个前导零。  s 秒。一位数的秒数没有前导零。  ss 秒。一位数的秒数有一个前导零。  f 毫秒的小数精度为一位。其余数字被截断。  ff 毫秒的小数精度为两位。其余数字被截断。  fff 毫秒的小数精度为三位。其余数字被截断。  ffff 毫秒的小数精度为四位。其余数字被截断。  fffff 毫秒的小数精度为五位。其余数字被截断。  ffffff 毫秒的小数精度为六位。其余数字被截断。  fffffff 毫秒的小数精度为七位。其余数字被截断。  t 在 AMDesignator 或 PMDesignator 中定义的 AM/PM 指示项的第一个字符(如果存在)。  tt 在 AMDesignator 或 PMDesignator 中定义的 AM/PM 指示项(如果存在)。  z 时区偏移量(“+”或“-”后面仅跟小时)。一位数的小时数没有前导零。例如,太平洋标准时间是“-8”。  zz 时区偏移量(“+”或“-”后面仅跟小时)。一位数的小时数有前导零。例如,太平洋标准时间是“-08”。  zzz 完整时区偏移量(“+”或“-”后面跟有小时和分钟)。一位数的小时数和分钟数有前导零。例如,太平洋标准时间是“-08:00”。  : 在 TimeSeparator 中定义的默认时间分隔符。  / 在 DateSeparator 中定义的默认日期分隔符。  % c 其中 c 是格式模式(如果单独使用)。如果格式模式与原义字符或其他格式模式合并,则可以省略“%”字符。  \ c 其中 c 是任意字符。照原义显示字符。若要显示反斜杠字符,请使用“\\”。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哎呦喂O_o嗨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值