一、簡(jiǎn)介
Calendar封裝了有關(guān)時(shí)間系統(tǒng)的信息,其中定義了年的開始和長(zhǎng)度等。它提供有關(guān)日歷的信息怠硼,并支持日歷計(jì)算,例如獲取符合條件的Date或DateComponents等趾断。
二、API
- 初始化
- 用戶當(dāng)前使用的日歷
public static var current: Calendar { get }
默認(rèn)為gregorian (current)
- 自動(dòng)跟蹤用戶設(shè)置的日歷
public static var autoupdatingCurrent: Calendar { get }
默認(rèn)為gregorian (autoupdatingCurrent)
- 通過identifier初始化
public init(identifier: Calendar.Identifier)
public enum Identifier {
case gregorian//公歷
case buddhist//佛歷
case chinese//農(nóng)歷
case coptic//科普特歷
case ethiopicAmeteMihret//埃塞俄比亞歷
case ethiopicAmeteAlem//埃塞俄比亞阿米特阿萊姆日歷
case hebrew//希伯來(lái)歷
case iso8601//國(guó)際標(biāo)準(zhǔn)歷法
case indian//印度國(guó)定歷
case islamic//伊斯蘭歷
case islamicCivil//伊斯蘭希吉來(lái)日歷
case japanese//和歷
case persian//波斯歷
case republicOfChina//民國(guó)紀(jì)年
case islamicTabular//伊斯蘭天文歷
case islamicUmmAlQura//伊斯蘭歷(烏姆庫(kù)拉)
}
let c = Calendar(identifier: .gregorian)//公歷
print(c)
//gregorian (fixed)
- 屬性
- 日歷的標(biāo)識(shí)符
public var identifier: Calendar.Identifier { get }
let c = Calendar(identifier: .gregorian)//公歷
print(c.identifier)
//gregorian
- 日歷的本地化
public var locale: Locale?
默認(rèn)為nil
- 日歷的時(shí)區(qū)
public var timeZone: TimeZone
默認(rèn)為Asia/Shanghai (current)
- 日歷的第一個(gè)工作日
public var firstWeekday: Int
默認(rèn)為1吩愧,表示為星期一芋酌。
- 第一周的最少天數(shù)
public var minimumDaysInFirstWeek: Int
默認(rèn)為1,表示某月的第一周只有一天雁佳。
- 標(biāo)志符
- 紀(jì)元標(biāo)志符
public var eraSymbols: [String] { get }
public var longEraSymbols: [String] { get }
在locale
屬性為en_US
時(shí)脐帝,eraSymbols
默認(rèn)為 ["BCE", "CE"]。
在locale
屬性為zh_CN
時(shí)糖权,eraSymbols
默認(rèn)為 ["公元前", "公元"]堵腹。
var c = Calendar(identifier: .gregorian)
c.locale = Locale(identifier: "en_US")
print(c.eraSymbols)
//["BCE", "CE"]
c.locale = Locale(identifier: "zh_CN")
print(c.eraSymbols)
//["公元前", "公元"]
在locale
屬性為en_US
時(shí),longEraSymbols
默認(rèn)為 ["Before Christ", "Anno Domini"]星澳。
在locale
屬性為zh_CN
時(shí)疚顷,longEraSymbols
默認(rèn)為 ["公元前", "公元"]。
- 月份標(biāo)志符
public var monthSymbols: [String] { get }
public var shortMonthSymbols: [String] { get }
public var veryShortMonthSymbols: [String] { get }
//獨(dú)立月份標(biāo)志符
public var standaloneMonthSymbols: [String] { get }
public var shortStandaloneMonthSymbols: [String] { get }
public var veryShortStandaloneMonthSymbols: [String] { get }
在locale
屬性為en_US
時(shí)禁偎,
monthSymbols
默認(rèn)為 ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]腿堤。
shortMonthSymbols
默認(rèn)為 ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]。
veryShortMonthSymbols
默認(rèn)為 ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"]如暖。
standaloneMonthSymbols
默認(rèn)為 ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]笆檀。
shortStandaloneMonthSymbols
默認(rèn)為 ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]。
veryShortStandaloneMonthSymbols
默認(rèn)為 ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"]盒至。
注:standaloneMonthSymbols
之類的獨(dú)立屬性用于日歷標(biāo)題之類的地方酗洒。monthSymbols
之類的非獨(dú)立屬性用于上下文("2020年12月18日 星期五"中的12月)士修。
- 星期標(biāo)志符
public var weekdaySymbols: [String] { get }
public var shortWeekdaySymbols: [String] { get }
public var veryShortWeekdaySymbols: [String] { get }
public var standaloneWeekdaySymbols: [String] { get }
public var shortStandaloneWeekdaySymbols: [String] { get }
public var veryShortStandaloneWeekdaySymbols: [String] { get }
在locale
屬性為en_US
時(shí),
weekdaySymbols
默認(rèn)為 ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]樱衷。
shortWeekdaySymbols
默認(rèn)為 ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]棋嘲。
veryShortWeekdaySymbols
默認(rèn)為 ["S", "M", "T", "W", "T", "F", "S"]。
standaloneWeekdaySymbols
默認(rèn)為 ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]箫老。
shortStandaloneWeekdaySymbols
默認(rèn)為 ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]封字。
veryShortStandaloneWeekdaySymbols
默認(rèn)為 ["S", "M", "T", "W", "T", "F", "S"]。
注:standaloneWeekdaySymbols
之類的獨(dú)立屬性用于日歷標(biāo)題之類的地方耍鬓。weekdaySymbols
之類的非獨(dú)立屬性用于上下文("2020年12月18日 星期五"中的星期五)阔籽。
- 季度標(biāo)志符
public var quarterSymbols: [String] { get }
public var shortQuarterSymbols: [String] { get }
public var standaloneQuarterSymbols: [String] { get }
public var shortStandaloneQuarterSymbols: [String] { get }
在locale屬性
為en_US
時(shí),
quarterSymbols
默認(rèn)為 ["1st quarter", "2nd quarter", "3rd quarter", "4th quarter"]牲蜀。
shortQuarterSymbols
默認(rèn)為 ["Q1", "Q2", "Q3", "Q4"]笆制。
standaloneQuarterSymbols
默認(rèn)為 ["1st quarter", "2nd quarter", "3rd quarter", "4th quarter"]。
shortStandaloneQuarterSymbols
默認(rèn)為 ["Q1", "Q2", "Q3", "Q4"]涣达。
注:standaloneQuarterSymbols
之類的獨(dú)立屬性用于日歷標(biāo)題之類的地方在辆。quarterSymbols
之類的非獨(dú)立屬性用于上下文("2020年12月18日 星期五 第四季度"中的 第四季度)。
- 時(shí)間段標(biāo)志符
public var amSymbol: String { get }
public var pmSymbol: String { get }
在locale
屬性為en_US
時(shí)度苔,
amSymbol
默認(rèn)為 AM匆篓。
pmSymbo
默認(rèn)為 PM。
- 范圍
- 指定組件的最小范圍限制
public func minimumRange(of component: Calendar.Component) -> Range<Int>?
public enum Component {
case era//紀(jì)元
case year//年
case month//月
case day//日
case hour//時(shí)
case minute//分
case second//秒
case weekday//周幾
case weekdayOrdinal//本月的第幾個(gè)周幾
case quarter//季度
case weekOfMonth//一個(gè)月的周數(shù)
case weekOfYear//一年的周數(shù)
case yearForWeekOfYear//ISO8601標(biāo)準(zhǔn)下的年份
case nanosecond//納秒
case calendar//日歷
case timeZone//時(shí)區(qū)
}
關(guān)于Component寇窑,可查看DateComponents的初始化方法了解詳細(xì)鸦概。
2月最少為28天,范圍為 1..<29甩骏。
let c = Calendar(identifier: .gregorian)
print(c.minimumRange(of: .day))
//Optional(Range(1..<29))
- 指定組件的最大范圍限制
public func maximumRange(of component: Calendar.Component) -> Range<Int>?
大月有31天窗市,范圍為 1..<32。
let c = Calendar(identifier: .gregorian)
print(c.maximumRange(of: .day))
//Optional(Range(1..<32))
- 小組件可以在大組件中使用的范圍
public func range(of smaller: Calendar.Component, in larger: Calendar.Component,
for date: Date) -> Range<Int>?
一年最多有366天饮笛,范圍為 1..<367咨察。
let c = Calendar(identifier: .gregorian)
print(c.range(of: .day, in: .year, for: Date()))
//Optional(Range(1..<367))
- 指定日期所處的開始日期與持續(xù)時(shí)間
public func dateInterval(of component: Calendar.Component, start: inout Date,
interval: inout TimeInterval, for date: Date) -> Bool
如果能成功計(jì)算開始日期與持續(xù)時(shí)間,則返回true福青。
如下如示摄狱,2020-12-18 07:45:49這個(gè)日期在.hour
下的開始日期為2020-12-18 07:00:00,持續(xù)時(shí)間為3600.0无午,指的就是2020-12-18 07:00:00-2020-12-18 08:00:00這個(gè)范圍二蓝。
let c = Calendar(identifier: .gregorian)
var d = Date()
var t = 0.0
print(d, t)
//2020-12-18 07:45:49 +0000 0.0
print(c.dateInterval(of: .hour, start: &d, interval: &t, for: d))
//ture
print(d, t)
//2020-12-18 07:00:00 +0000 3600.0
- 指定日期所處的日期范圍
public func dateInterval(of component: Calendar.Component, for date: Date)
-> DateInterval?
功能與上面方法相同,返回的是日期范圍指厌。
如下刊愚,2020-12-18 07:54:13在.hour
下的日期范圍為
2020-12-18 07:00:00 +0000 to 2020-12-18 08:00:00 +0000
let c = Calendar(identifier: .gregorian)
let d = Date()
print(d)
//2020-12-18 07:54:13 +0000
print(c.dateInterval(of: .hour, for: Date()))
//Optional(2020-12-18 07:00:00 +0000 to 2020-12-18 08:00:00 +0000)
- 指定日期的小組件位于大組件的排序位置
public func ordinality(of smaller: Calendar.Component, in larger: Calendar.Component,
for date: Date) -> Int?
如下,2020-12-18 08:33:00 +0000在上海時(shí)區(qū)的時(shí)間為16:33:00踩验,返回的17指的是在.hour
下16時(shí)為當(dāng)天的第17個(gè)小時(shí)鸥诽,0時(shí)為第1個(gè)小時(shí)商玫。
let c = Calendar(identifier: .gregorian)
let d = Date()
print(d)
//2020-12-18 08:33:00 +0000
print(c.ordinality(of: .hour, in: .day, for: d))
//Optional(17)
- 日期的修改
- 通過日期組件
public func date(byAdding components: DateComponents, to date: Date,
wrappingComponents: Bool = false) -> Date?
給日期增加時(shí)間組件的各組件值,獲得一個(gè)新日期牡借。
wrappingComponents
為true時(shí)拳昌,當(dāng)組件值超時(shí)最大限制時(shí),會(huì)減去其最大值钠龙。
如下炬藤,當(dāng)給當(dāng)前日期增加了25小時(shí)后,實(shí)際上只增加了1小時(shí)碴里。
let c = Calendar(identifier: .gregorian)
let d = Date()
print(d)
//2020-12-18 08:51:51 +0000
print(c.date(byAdding: DateComponents(hour: 25), to: d, wrappingComponents: true))
Optional(2020-12-18 09:51:51 +0000)
- 通過日歷組件
public func date(byAdding component: Calendar.Component, value: Int, to date: Date,
wrappingComponents: Bool = false) -> Date?
與上面方法不同的是沈矿,該方法只能一次更改單個(gè)組件的值,而上面方法可以同時(shí)更改多個(gè)組件的值咬腋。
wrappingComponents
的作用也與上面方法一致羹膳。
let c = Calendar(identifier: .gregorian)
let d = Date()
print(d)
//2020-12-19 06:08:25 +0000
print(c.date(byAdding: .hour, value: 30, to: d, wrappingComponents: true))
//Optional(2020-12-19 12:08:25 +0000)
- 日期組件
- 日期組件轉(zhuǎn)換為日期
public func date(from components: DateComponents) -> Date?
let c = Calendar(identifier: .gregorian)
print(c.date(from: DateComponents(year: 2020, month: 12, day: 12,
hour: 12, minute: 12, second: 12)))
//Optional(2020-12-12 04:12:12 +0000)
- 通過日歷組件將日期轉(zhuǎn)換為日期組件
public func dateComponents(_ components: Set<Calendar.Component>,
from date: Date) -> DateComponents
該方法會(huì)獲取屬性不完整的日期組件。
let c = Calendar(identifier: .gregorian)
print(c.dateComponents([.year, .month, .day, .hour, .minute, .second], from: Date()))
//year: 2020 month: 12 day: 19 hour: 14 minute: 20 second: 52 isLeapMonth: false
- 通過時(shí)區(qū)將日期轉(zhuǎn)換為日期組件
public func dateComponents(in timeZone: TimeZone, from date: Date) -> DateComponents
該方法會(huì)獲取屬性完整的日期組件根竿。
let c = Calendar(identifier: .gregorian)
print(c.dateComponents(in: TimeZone.current, from: Date()))
//calendar: gregorian (fixed) timeZone: Asia/Shanghai (current) era: 1 year: 2020
//month: 12 day: 19 hour: 14 minute: 24 second: 56 nanosecond: 984720945
//weekday: 7 weekdayOrdinal: 3 quarter: 0 weekOfMonth: 3 weekOfYear: 51
//yearForWeekOfYear: 2020 isLeapMonth: false
- 獲取兩個(gè)日期的差
public func dateComponents(_ components: Set<Calendar.Component>, from start: Date,
to end: Date) -> DateComponents
差值通過日期組件展示陵像。
let c = Calendar(identifier: .gregorian)
print(c.dateComponents([.hour, .minute, .second], from: Date(), to: Date()+10000))
//hour: 2 minute: 46 second: 40 isLeapMonth: false
- 獲取兩個(gè)日期組件的差
public func dateComponents(_ components: Set<Calendar.Component>,
from start: DateComponents, to end: DateComponents) -> DateComponents
差值通過日期組件展示。
let c = Calendar(identifier: .gregorian)
print(c.dateComponents([.hour, .minute, .second], from: DateComponents(hour: 10),
to: DateComponents(hour: 12, minute: 12, second: 12)))
//hour: 2 minute: 12 second: 12 isLeapMonth: false
- 獲取指定日期對(duì)應(yīng)日歷組件的值
public func component(_ component: Calendar.Component, from date: Date) -> Int
let c = Calendar(identifier: .gregorian)
print(Date())
//2020-12-19 06:43:03 +0000
print(c.component(.hour, from: Date()))
//14
- 日期的運(yùn)算
- 獲取指定日期的開始日期
public func startOfDay(for date: Date) -> Date
let c = Calendar(identifier: .gregorian)
print(Date())
//2020-12-19 06:44:32 +0000
print(c.startOfDay(for: Date()))
//2020-12-18 16:00:00 +0000
- 比較兩日期對(duì)應(yīng)組件值的大小
public func compare(_ date1: Date, to date2: Date,
toGranularity component: Calendar.Component) -> ComparisonResult
public enum ComparisonResult : Int {
case orderedAscending = -1//升序
case orderedSame = 0//相等
case orderedDescending = 1//降序
}
注:并不是單獨(dú)比較組件的值寇壳。比如.second
時(shí)醒颖,2分1秒也會(huì)大于1分59秒。實(shí)際上是將日期轉(zhuǎn)換為秒壳炎,再比較大小泞歉。
let c = Calendar(identifier: .gregorian)
print(c.compare(Date(), to: Date()+59, toGranularity: .second).rawValue)
//-1
- 兩日期對(duì)應(yīng)組件值是否相同
public func isDate(_ date1: Date, equalTo date2: Date,
toGranularity component: Calendar.Component) -> Bool
注:并不是單獨(dú)比較組件的值。比如.second
時(shí)冕广,2分1秒也會(huì)大于1分1秒疏日。實(shí)際上是將日期轉(zhuǎn)換為秒偿洁,再比較大小撒汉。
let c = Calendar(identifier: .gregorian)
print(c.isDate(Date(), equalTo: Date()+60, toGranularity: .second))
//false
- 兩日期是否在同一天
public func isDate(_ date1: Date, inSameDayAs date2: Date) -> Bool
- 指定日期是否屬于今天
public func isDateInToday(_ date: Date) -> Bool
- 指定日期是否屬于昨天
public func isDateInYesterday(_ date: Date) -> Bool
- 指定日期是否屬于明天
public func isDateInTomorrow(_ date: Date) -> Bool
- 指定日期是否屬于周末
public func isDateInWeekend(_ date: Date) -> Bool
注意:有些地區(qū)的周末并不是周六與周日。
- 獲取指定日期的周末開始日期與持續(xù)時(shí)間
public func dateIntervalOfWeekend(containing date: Date, start: inout Date,
interval: inout TimeInterval) -> Bool
若能獲取到周末涕滋,該方法返回true睬辐。
如下,因?yàn)榻裉焓侵芰龇危虼酥苣┦菑慕裉扉_始溯饵,持續(xù)172800.0秒,也就是2天锨用。
let c = Calendar(identifier: .gregorian)
var d = Date()
var i = 0.0
print(d, i)
//2020-12-19 07:14:33 +0000 0.0
print(c.dateIntervalOfWeekend(containing: Date(), start: &d, interval: &i))
//true
print(d, i)
//2020-12-18 16:00:00 +0000 172800.0
- 獲取指定日期的周末的范圍
public func dateIntervalOfWeekend(containing date: Date) -> DateInterval?
功能與上面方法相同丰刊,只不過直接返回日期間隔。
let c = Calendar(identifier: .gregorian)
print(c.dateIntervalOfWeekend(containing: Date()))
//Optional(2020-12-18 16:00:00 +0000 to 2020-12-20 16:00:00 +0000)
- 返回指定日期的下一個(gè)周末開始日期與持續(xù)時(shí)間
public func nextWeekend(startingAfter date: Date, start: inout Date,
interval: inout TimeInterval, direction: Calendar.SearchDirection = .forward) -> Bool
public enum SearchDirection {
case forward//查詢?nèi)掌诟蟮姆较蛟鲇担轮苣? case backward//查詢?nèi)掌诟蟮姆较蜃那桑现苣?}
若能獲取到周末寻歧,該方法返回true。
功能與dateIntervalOfWeekend
方法大致相同秩仆。
不同在于码泛,如下,因?yàn)榻裉焓侵芰?code>nextWeekend會(huì)獲取到下一個(gè)星期的周末澄耍,而dateIntervalOfWeekend
會(huì)獲取到本周末噪珊。
let c = Calendar(identifier: .gregorian)
var d = Date()
var i = 0.0
print(d, i)
//2020-12-19 07:35:25 +0000 0.0
print(c.dateIntervalOfWeekend(containing: Date(), start: &d, interval: &i))
//true
print(d, i)
//2020-12-18 16:00:00 +0000 172800.0
print(c.nextWeekend(startingAfter: Date(), start: &d, interval: &i))
//true
print(d, i)
//2020-12-25 16:00:00 +0000 172800.0
- 獲取指定日期的下一個(gè)周末的范圍
public func nextWeekend(startingAfter date: Date,
direction: Calendar.SearchDirection = .forward) -> DateInterval?
功能與上面方法相同,只不過直接返回日期間隔齐莲。
let c = Calendar(identifier: .gregorian)
print(Date())
//2020-12-19 07:42:47 +0000
print(c.nextWeekend(startingAfter: Date()))
//Optional(2020-12-25 16:00:00 +0000 to 2020-12-27 16:00:00 +0000)
- 日期的匹配
- 匹配滿足日期組件(或最接近)的日期
public func enumerateDates(startingAfter start: Date,
matching components: DateComponents,
matchingPolicy: Calendar.MatchingPolicy,
repeatedTimePolicy: Calendar.RepeatedTimePolicy = .first,
direction: Calendar.SearchDirection = .forward,
using block: (Date?, Bool, inout Bool) -> Void)
如果不可能完全匹配痢站,并且matchingPolicy
為strict
,則會(huì)將nil傳遞給閉包铅搓,并且枚舉結(jié)束瑟押。
邏輯上,strict
匹配將無(wú)限期地搜索到將來(lái)星掰,但如果找不到匹配項(xiàng)多望,則繼續(xù)進(jìn)行枚舉并沒有意義。
若已成功匹配日期氢烘,可通過在閉包中將inout Bool
值設(shè)置為true來(lái)停止枚舉并函數(shù)返回怀偷。
匹配策略
public enum MatchingPolicy {
//如果DateComponents的下一個(gè)更高組件沒有匹配的時(shí)間,算法將返回存在的現(xiàn)有時(shí)間播玖。
//例如椎工,在夏令時(shí)過渡時(shí)間可能沒有2:37 am,那么結(jié)果將是3:00 am蜀踏。
case nextTime
//與nextTime相同维蒙,但會(huì)保留下一個(gè)組件值。
//例如果覆,在夏令時(shí)過渡時(shí)間可能沒有2:37 am颅痊,那么結(jié)果將是3:37 am。
case nextTimePreservingSmallerComponents
//與nextTime相同局待,但會(huì)減小組件值和保留下一個(gè)組件值斑响。
//例如,在夏令時(shí)過渡時(shí)間可能沒有2:37 am钳榨,那么結(jié)果將是1:37 am舰罚。
case previousTimePreservingSmallerComponents
//精確查詢匹配項(xiàng)
//例如,在公歷中搜索2月29日薛耻,上面的三個(gè)枚舉選項(xiàng)可能改為選擇3月1日(如果年份不是閏年)营罢。
case strict
}
結(jié)果選擇策略
public enum RepeatedTimePolicy {
//有多個(gè)匹配結(jié)果時(shí),將返回第一個(gè)結(jié)果
case first
//有多個(gè)匹配結(jié)果時(shí)饼齿,將返回最后一個(gè)結(jié)果
case last
}
查詢方向
public enum SearchDirection {
case forward//向日期更大的方向查詢
case backward//向日期更小的方向查詢
}
閉包
(Date?, Bool, inout Bool) -> Void
Date?
為匹配到的日期饲漾。
Bool
為true時(shí)瘟滨,表示此日期為完全匹配日期組件。
inout Bool
賦值為true后能颁,會(huì)停止遍歷杂瘸。
let c = Calendar(identifier: .gregorian)
c.enumerateDates(startingAfter: Date(), matching: DateComponents(month: 2, day: 29),
matchingPolicy: .nextTime, repeatedTimePolicy: .first) { (a, b, c) in
let formatter = DateFormatter()
formatter.dateFormat = "yyyy-MM-dd HH:mm:ss"
print(formatter.string(from: a!), b , c)
if b {
//b為true表示完全匹配日期組件
//matchingPolicy為strict時(shí),所有結(jié)果的b都為true
c = true//設(shè)置為true可停止遍歷
}
}
//2021-03-01 00:00:00 false false
//2022-03-01 00:00:00 false false
//2023-03-01 00:00:00 false false
//2024-02-29 00:00:00 true false
- 獲取第一個(gè)滿足日期組件(或最接近)的日期
public func nextDate(after date: Date, matching components: DateComponents,
matchingPolicy: Calendar.MatchingPolicy,
repeatedTimePolicy: Calendar.RepeatedTimePolicy = .first,
direction: Calendar.SearchDirection = .forward) -> Date?
功能與enumerateDates
方法相同伙菊,但只返回第一個(gè)匹配的日期败玉。
let a = c.nextDate(after: Date(), matching: DateComponents(month: 2, day: 29),
matchingPolicy: .nextTime, repeatedTimePolicy: .first, direction: .forward)
let formatter = DateFormatter()
formatter.dateFormat = "yyyy-MM-dd HH:mm:ss"
print(formatter.string(from: a!))
- 日期是否匹配日期組件
public func date(_ date: Date, matchesComponents components: DateComponents) -> Bool
let c = Calendar(identifier: .gregorian)
print(Date())
//2020-12-21 07:53:08 +0000
print(c.date(Date(), matchesComponents: DateComponents(month: 12, day: 21)))
//true
- 日期的更改
- 通過組件值更改日期
public func date(bySetting component: Calendar.Component, value: Int,
of date: Date) -> Date?
枚舉參數(shù)可查看enumerateDates
方法。
更改組件值時(shí)通常會(huì)要求同時(shí)更高或耦合的組件镜硕。例如运翼,將weekday
設(shè)置為“星期四”的通常還要求更改day
的組件值,并且可能還要求更改month
和year
兴枯。
如果不存在滿足條件的日期血淌,此時(shí)會(huì)返回下一個(gè)可用日期。
當(dāng)更改組件值時(shí)财剖,更小組件值會(huì)重置悠夯。例如將month
變成3,那么結(jié)果會(huì)變成03-01 00:00:00
let c = Calendar(identifier: .gregorian)
print(Date())
//2020-12-21 07:29:09 +0000
let d = c.date(bySetting: .month, value: 3, of: Date())
//Optional(2021-02-28 16:00:00 +0000)
print(d)
- 通過時(shí)分秒更改日期
public func date(bySettingHour hour: Int, minute: Int, second: Int, of date: Date,
matchingPolicy: Calendar.MatchingPolicy = .nextTime,
repeatedTimePolicy: Calendar.RepeatedTimePolicy = .first,
direction: Calendar.SearchDirection = .forward) -> Date?
枚舉參數(shù)可查看enumerateDates
方法躺坟。
如果不存在滿足條件的日期沦补,此時(shí)會(huì)返回下一個(gè)可用日期。
let c = Calendar(identifier: .gregorian)
let formatter = DateFormatter()
formatter.dateFormat = "yyyy-MM-dd HH:mm:ss"
print(formatter.string(from: Date()))
//2020-12-21 15:48:26
let a = c.date(bySettingHour: 11, minute: 12, second: 13, of: Date())
print(formatter.string(from: a!))
//2020-12-21 11:12:13