TimeZone

一、简介

TimeZone 定义了时区的行为,
时区值 表示 相对 格林威治标准时间(GMT)的 时间偏移量(正或负)。
请注意,America/Los_Angeles 是 时区 的 ID ,而不是名称。
时区名称 的 示例是 Pacific Daylight Time。

二、API
获取系统当前使用的时区
当前时区  
public static var current: TimeZone { get }
var tz = TimeZone.current
print(tz)
//Asia/Shanghai (current)
当前时区 该方法会自动跟踪用户所做的更新。
public static var autoupdatingCurrent: TimeZone { get }
var tz = TimeZone.autoupdatingCurrent
print(tz)
// Asia/Shanghai (autoupdatingCurrent)

初始化
通过 id     
public init?(identifier: String)
系统自带的 id 可通过 knownTimeZoneIdentifiers 方法获取 。
var tz = TimeZone(identifier: "Asia/Shanghai")
print(tz)
// Optional(Asia/Shanghai (current))

通过相对于格林尼治标准时间(GMT)的偏移量

public init?(secondsFromGMT seconds: Int)

中国属于东八区,则偏移 8 个小时。

var tz = TimeZone(secondsFromGMT: 3600*8)
print(tz)
// Optional(GMT+0800 (fixed))
通过缩写
public init?(abbreviation: String)

通常,不鼓励使用缩写,除了GMT之类的独特实例。
时区缩写不是标准化的,因此给定的缩写可能具有多种含义。
例如,EST是指美国和澳大利亚的东部时间。
系统自带的缩写可通过 abbreviationDictionary 方法获取。

var tz = TimeZone(abbreviation: "HKT")
print(tz)
//Optional(Asia/Hong_Kong (fixed))
获取时区的 id
public var identifier: String { get }
public init?(identifier: String) 可使用该 id 初始化 。

var tz = TimeZone.current
print(tz.identifier)
// Asia/Shanghai
获取相对于格林尼治标准时间(GMT)的时间偏移量
public func secondsFromGMT(for date: Date = Date()) -> Int
public init?(secondsFromGMT seconds: Int) 可使用该偏移量初始化。

var tz = TimeZone.current
print(tz.secondsFromGMT())
// 28800
获取时区的缩写
public func abbreviation(for date: Date = Date()) -> String?
public init?(abbreviation: String) 可通过该缩写初始化。
请注意,缩写在不同的日期可能有所不同。
例如,在夏令时期间,US/Eastern 时区的缩写为 EDT。
在其他时候,它的缩写是 EST。

var tz = TimeZone.current
print(tz.abbreviation())
//Optional("GMT+8")

夏令时
夏令时又称“经济时”或“日光节约时”。法定时的一种。
在夏季,由于昼长夜短,为充分利用日光,把时钟适当拨快;
到秋季,再拨回。1908年由英国人威利特提出。
1916年后,德国、奥地利、荷兰及丹麦等国相继采用。
中国也曾采用过。


是否在指定日期使用夏令时
public func isDaylightSavingTime(for date: Date = Date()) -> Bool
var tz = TimeZone.current
print(tz.isDaylightSavingTime())
// false
获取指定日期的夏令时偏移量
public func daylightSavingTimeOffset(for date: Date = Date()) -> TimeInterval
中国未使用夏令时,因此偏移量为 0 。
var tz = TimeZone.current
print(tz.daylightSavingTimeOffset())
// 0.0
获取指定日期之后的下一个夏令时过渡的日期
public func nextDaylightSavingTimeTransition(after date: Date) -> Date?
若未使用夏令时,则返回 nil 。
var tz = TimeZone.current
print(tz.nextDaylightSavingTimeTransition(after: Date()))
// nil
获取当前日期之后的下一个夏令时过渡的日期
public var nextDaylightSavingTimeTransition: Date? { get }
若未使用夏令时,则返回 nil 。
var tz = TimeZone.current
print(tz.nextDaylightSavingTimeTransition)
// nil
获取系统已知的所有时区的 id
public static var knownTimeZoneIdentifiers: [String] { get }
print(TimeZone.knownTimeZoneIdentifiers)
// ["Africa/Abidjan", "Africa/Accra", "Africa/Addis_Ababa", "Africa/Algiers", 
// "Africa/Asmara", "Africa/Bamako", "Africa/Bangui", "Africa/Banjul", "Africa/Bissau", 
// "Africa/Blantyre", "Africa/Brazzaville", "Africa/Bujumbura", "Africa/Cairo", 
获取缩写与 时区 id 的 映射字典
public static var abbreviationDictionary: [String : String]
print(TimeZone.abbreviationDictionary)
// ["CLST": "America/Santiago", "PHT": "Asia/Manila", "PET": "America/Lima",
/ /"COT": "America/Bogota", "MDT": "America/Denver", "MSD": "Europe/Moscow", 
// "NST": "America/St_Johns", "EEST": "Europe/Athens", "BRT":"America/Sao_Paulo"
获取时区数据的版本
public static var timeZoneDataVersion: String { get }
print(TimeZone.timeZoneDataVersion)
// 2020d
获取指定语言环境本地化的时区名称
public func localizedName(for style: NSTimeZone.NameStyle, locale: Locale?) -> String? 
public enum NameStyle : Int {
        case standard = 0 // 标准
        case shortStandard = 1
        case daylightSaving = 2 // 夏令时
        case shortDaylightSaving = 3
        case generic = 4 // 通用
        case shortGeneric = 5
}
var tz = TimeZone.current
print(tz.localizedName(for: .standard, locale: Locale(identifier: "zh")))
// Optional("中国标准时间")

推荐阅读更多精彩内容