1.Date
date是一個表示時間的結構體,獨立于任何系統,任何日歷系統。
使用如下:
let now = Date()
//5分鐘前的date
let fiveMAgo = Date(timeIntervalSinceNow: -5 * 60)
let fiveMLater = Date(timeIntervalSinceNow: 5 * 60)
//相對于參考時間
let first = Date(timeIntervalSinceReferenceDate: -875_602_800)
let second = Date(timeIntervalSinceReferenceDate: 875_602_800)
//獲得一年的秒數
let oneYear = TimeInterval(60 * 60 * 24 * 365)
let new1971 = Date(timeIntervalSince1970: oneYear)
let new1969 = Date(timeIntervalSince1970: -oneYear)
//相對于指定時間
let newYear = Date(timeInterval: oneYear, since: now)
2.Calendar和DateComponents
calendar日歷,也是一個結構體。包含了16中不同的日歷系統,其中包括了Gregorian就是我們所說的公歷。
DateComponents日期的組件,也是一個結構體,包含了年、月、日、時、分、秒等等組件。
calendar的作用,就是將Date轉換為DateComponents,或者DateComponents轉成Date。
所以使用calendar,我們可以通過年月日等組件獲得一個date。或者從date中讀取出時分秒等屬性。
使用如下:
//創建當前日歷
let userCalendar = Calendar.current
//創建出組件,提供值
let components = DateComponents(calendar: nil,
timeZone: nil,
era: nil,
year: 2000,
month: 3,
day: 10,
hour: nil,
minute: nil,
second: nil,
nanosecond: nil,
weekday: nil,
weekdayOrdinal: nil,
quarter: nil,
weekOfMonth: nil,
weekOfYear: nil,
yearForWeekOfYear: nil)
//創建出date
let userDate = userCalendar.date(from: components)
//獲得相對秒數
userDate?.timeIntervalSinceReferenceDate
//另外一種方式
var components2 = DateComponents()
components2.year = 2000
components2.month = 4
components2.day = 3
let userDate2 = userCalendar.date(from: components2)
//通過date獲得組件
let date2 = Date()
let com2 = userCalendar.dateComponents([.year, .month, .hour], from: date2)
com2.year
com2.month
com2.hour
屬性 | 作用 |
---|---|
calendar | 日歷系統,這個值默認是gregorian。 |
day | 日。如2010年1月27日18時00分,這個值是27。 |
era | 這個特定日期的時代,這取決于日期的日歷系統。在這種情況下,我們使用公歷,它有兩個時代:BCE(又稱BC),由整數值0表示CE(又名AD),以整數值1表示 |
hour | 時 |
minute | 分 |
month | 月 |
nanosecond | 納秒 |
quarter | 季度 |
second | 秒 |
timeZone | 時區 |
weekday | 星期幾 |
weekdayOrdinal | 下一個更大的指定日歷單元中的工作日的位置,在這種情況下為一個月。所以這指定了給定月份的第n個工作日。2010年9月27日,Jauary在本月的第四個星期三,所以這個值是4。 |
weekOfMonth | 一年中的星期 |
weekOfYear | 一年中的周 |
year | 年 |
yearForWeekOfYear | 參照字面意思 |
3.date和string
兩者之間通過DateFormatter相互轉換
//date -> string
let myFormatter = DateFormatter()
//這里有很多默認的日期格式
myFormatter.dateStyle = .long
//默認的時間格式
myFormatter.timeStyle = .long
myFormatter.string(from: date2)
//也可以使用自定義的格式
myFormatter.dateFormat = "MMM d, yyyy, hh:mm a zz"
myFormatter.string(from: date2)
//string -> date
let date = myFormatter.date(from: "May 18, 2017, 03:50 PM GMT+8")
date
4.日期之間的比較
var component1 = DateComponents()
component1.year = 2001
component1.month = 1
component1.day = 9
component1.hour = 10
//時區
component1.timeZone = TimeZone(abbreviation: "PST")
let date1 = userCalendar.date(from: component1)
var formatter = DateFormatter()
formatter.calendar = userCalendar
formatter.dateFormat = "MMM d, yyyy, hh:mm a zz"
let date22 = formatter.date(from: "Jan 27, 2010, 10:00 AM PST")
//可以直接使用> < ==比較
date1! > date22!
5.日期的計算
//兩個日期的間隔秒數
date1!.timeIntervalSince(date22!)
//比較兩個日期的天數
let between = userCalendar.dateComponents([.year], from: date1!, to: date22!)
between.year
//在date1的基礎上,增加90天
userCalendar.date(byAdding: .day, value: 90, to: date1!)
//在date1基礎上,增加日期組件后的date
var com = DateComponents()
com.hour = 4
com.minute = 4
userCalendar.date(byAdding: com, to: date1!)