-
vb.net 教程 1-8 日期时间类型2
版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。
可惜的是TimeSpan没有提供TimeSpan.Months这样的方法。那么还有没有办法求相差的月份呢?
vb.net还提供了DateDiff()方法。
DateDiff 属于 Microsoft.VisualBasic 命名空间,我个人理解是.net为了兼容之前的vb专门建立的命名空间。
我们来看看DateDiff的说明:
DateDiff(DateInterval, DateTime, DateTime, FirstDayOfWeek, FirstWeekOfYear) 返回一个 Long 值,该值指定两个 Date 值之间的时间间隔数。
使用DateDiff 的代码如下:
Sub Main()
Dim date1, date2 As DateTime
date1 = Date.Now()
date2 = New DateTime(2018, 5, 12, 10, 12, 13)
Dim yearDiff As Integer
Dim monthDiff As Integer
Dim dayDiff As Integer
Dim hourDiff As Integer
Dim minuteDiff As Integer
Dim secondDiff As Integer
yearDiff = DateDiff("yyyy", date1, date2)
monthDiff = DateDiff("M", date1, date2)
dayDiff = DateDiff("d", date1, date2)
hourDiff = DateDiff("H", date1, date2)
minuteDiff = DateDiff("n", date1, date2)
secondDiff = DateDiff("s", date1, date2)
Console.WriteLine("{0} 与 {1}", Format(date1, "yyyy年M月d日 H时m分s秒"), Format(date2, "yyyy年M月d日 H时m分s秒"))
Console.WriteLine("相差年份:{0}", yearDiff)
Console.WriteLine("相差月份:{0}", monthDiff)
Console.WriteLine("相差天数:{0}", dayDiff)
Console.WriteLine("相差小时:{0}", hourDiff)
Console.WriteLine("相差分钟:{0}", minuteDiff)
Console.WriteLine("相差秒钟:{0}", secondDiff)
Console.ReadKey()
End Sub
运行结果如下:
DateDiff()的第一个参数是一个字符串或者是DateInterval 枚举,包括DateInterval.Year 等。
例如:
minuteDiff = DateDiff("n", date1, date2)
等同于:
minuteDiff = DateDiff(DateInterval.Minute, date1, date2)
下表来自于MSDN:
枚举值
字符串值 时间差额的单位
DateInterval.Day "d" 天
DateInterval.DayOfYear "y" 天
DateInterval.Hour "h" 小时
DateInterval.Minute "n" 分钟
DateInterval.Month "m" 月份
DateInterval.Quarter "q" 季度
DateInterval.Second "s" 秒
DateInterval.Weekday "w" 周
DateInterval.WeekOfYear "ww" 日历周
DateInterval.Year "yyyy" 年份
如果在现有日期时间基础上增加或减少求得新的日期时间呢?
DateTime.AddYears、DateTime.AddMonth。。。。
例如以下代码在现在时间基础上增加25小时:
Sub Main()
Dim date1, date2 As DateTime
date1 = Date.Now()
date2 = date1.AddHours(25)
Dim date3 As TimeSpan
date3 = date2.Subtract(date1)
Console.WriteLine("{0} 与 {1}", Format(date1, "yyyy年M月d日 H时m分s秒"), Format(date2, "yyyy年M月d日 H时m分s秒"))
Console.WriteLine("相差小时:" & date3.Hours)
Console.WriteLine("相差小时:" & date3.TotalHours)
Console.ReadKey()
End Sub
运行结果如下:
同时,我们也在代码中看出 date3.Hours 和 date3.TotalHours 的不同。
最后附注说明的是,不要以为Add就是增加,如果里面的参数是负数,那么就是减少了,例如上述代码中
date2 = date1.AddHours(49) 修改为: date2 = date1.AddHours(-49)
我们来看看结果:
由于.net平台下C#和vb.NET很相似,本文也可以为C#爱好者提供的参考。
学习更多vb.net知识,请参看 vb.net 教程 目录
————————————————
版权声明:本文为CSDN博主「VB.Net」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/uruseibest/article/details/63272722
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数