刚开始操场。我正在尝试创建一个简单的应用程序。
我创建了一个这样的日期对象:
var date = NSDate()
如何获得当前时间?在其他语言中,我可以这样做:
var hour = date.hour
但是我找不到那样的属性/方法。我找到了一种方法dateWithCalendarFormat
。我应该用吗?如果是这样,怎么样?
答案 0 :(得分:344)
Swift 3的更新:
let date = Date()
let calendar = Calendar.current
let hour = calendar.component(.hour, from: date)
let minutes = calendar.component(.minute, from: date)
我这样做:
let date = NSDate()
let calendar = NSCalendar.currentCalendar()
let components = calendar.components(.CalendarUnitHour | .CalendarUnitMinute, fromDate: date)
let hour = components.hour
let minutes = components.minute
在objective-c How do I get hour and minutes from NSDate?
中查看相同的问题与Nate的回答相比,你会得到这个数字,而不是字符串...选择你的选择!
答案 1 :(得分:159)
使用Swift 4进行测试
您可以像这样简单地获取当前日期和时间:
let currentDateTime = Date()
但是,Date
是一个64位浮点数,用于衡量自2001年1月1日00:00:00 UTC的参考日期以来的秒数。我可以使用
Date().timeIntervalSinceReferenceDate
在撰写本文时,它返回497626515.185066
,可能并不完全符合您的要求。继续阅读。
方法1
如果您知道参考日期之前或之后的秒数,则可以使用它。
let someOtherDateTime = Date(timeIntervalSinceReferenceDate: -123456789.0) // Feb 2, 1997, 10:26 AM
方法2
当然,使用诸如年,月,日和小时(而不是相对秒)之类的东西来制作Date
会更容易。为此,您可以使用DateComponents
指定组件,然后使用Calendar
创建日期。 Calendar
提供Date
上下文。否则,它将如何知道在哪个时区或日历中表达?
// Specify date components
var dateComponents = DateComponents()
dateComponents.year = 1980
dateComponents.month = 7
dateComponents.day = 11
dateComponents.timeZone = TimeZone(abbreviation: "JST") // Japan Standard Time
dateComponents.hour = 8
dateComponents.minute = 34
// Create date from components
let userCalendar = Calendar.current // user calendar
let someDateTime = userCalendar.date(from: dateComponents)
可以找到其他时区缩写here。如果将其留空,则默认为使用用户的时区。
方法3
最简洁的方式(但不一定是最好的)可能是DateFormatter
。
let formatter = DateFormatter()
formatter.dateFormat = "yyyy/MM/dd HH:mm"
let someDateTime = formatter.date(from: "2016/10/08 22:31")
DateFormatter
支持的Unicode technical standards show other formats。
方法1
如果您只想显示日期或时间的某些组成部分,可以使用CalendarUnit
指定要从Date
中提取的组件。
// get the current date and time
let currentDateTime = Date()
// get the user's calendar
let userCalendar = Calendar.current
// choose which date and time components are needed
let requestedComponents: Set<Calendar.Component> = [
.year,
.month,
.day,
.hour,
.minute,
.second
]
// get the components
let dateTimeComponents = userCalendar.dateComponents(requestedComponents, from: currentDateTime)
// now the components are available
dateTimeComponents.year // 2016
dateTimeComponents.month // 10
dateTimeComponents.day // 8
dateTimeComponents.hour // 22
dateTimeComponents.minute // 42
dateTimeComponents.second // 17
另见this answer。
方法2
方法1为您提供了组件,但为每种样式,语言和区域格式化这些数字需要做很多工作。你不需要。已经使用DateFormatter
类为您完成了这项工作。
// get the current date and time
let currentDateTime = Date()
// initialize the date formatter and set the style
let formatter = DateFormatter()
formatter.timeStyle = .medium
formatter.dateStyle = .long
// get the date time String from the date object
formatter.string(from: currentDateTime) // October 8, 2016 at 10:48:53 PM
以上是上述代码的延续,显示了更多格式选项:
// "10/8/16, 10:52 PM"
formatter.timeStyle = .short
formatter.dateStyle = .short
formatter.string(from: currentDateTime)
// "Oct 8, 2016, 10:52:30 PM"
formatter.timeStyle = .medium
formatter.dateStyle = .medium
formatter.string(from: currentDateTime)
// "October 8, 2016 at 10:52:30 PM GMT+8"
formatter.timeStyle = .long
formatter.dateStyle = .long
formatter.string(from: currentDateTime)
// "October 8, 2016"
formatter.timeStyle = .none
formatter.dateStyle = .long
formatter.string(from: currentDateTime)
// "10:52:30 PM"
formatter.timeStyle = .medium
formatter.dateStyle = .none
formatter.string(from: currentDateTime)
请记住,这是针对英语的,并且该地区设置为美国。对于其他语言和区域,格式将看起来不同。
答案 2 :(得分:55)
您也可以使用NSDateFormatter的便捷方法,例如
func printTimestamp() {
let timestamp = NSDateFormatter.localizedStringFromDate(NSDate(), dateStyle: .MediumStyle, timeStyle: .ShortStyle)
print(timestamp)
}
printTimestamp() // Prints "Sep 9, 2014, 4:30 AM"
答案 3 :(得分:49)
Swift使创建和使用扩展变得非常容易。我创建了一个sharedCode.swift
文件,并在其中添加了枚举,扩展和其他有趣的内容。我创建了一个NSDate
扩展名来添加一些典型的功能,这些功能一次又一次地输入是费力和丑陋的:
extension NSDate
{
func hour() -> Int
{
//Get Hour
let calendar = NSCalendar.currentCalendar()
let components = calendar.components(.Hour, fromDate: self)
let hour = components.hour
//Return Hour
return hour
}
func minute() -> Int
{
//Get Minute
let calendar = NSCalendar.currentCalendar()
let components = calendar.components(.Minute, fromDate: self)
let minute = components.minute
//Return Minute
return minute
}
func toShortTimeString() -> String
{
//Get Short Time String
let formatter = NSDateFormatter()
formatter.timeStyle = .ShortStyle
let timeString = formatter.stringFromDate(self)
//Return Short Time String
return timeString
}
}
使用此扩展程序,您现在可以执行以下操作:
//Get Current Date
let currentDate = NSDate()
//Test Extensions in Log
NSLog("(Current Hour = \(currentDate.hour())) (Current Minute = \(currentDate.minute())) (Current Short Time String = \(currentDate.toShortTimeString()))")
上午11:51会写出:
(当前小时= 11)(当前分钟= 51)(当前短时间字符串= 11:51 AM)
答案 4 :(得分:26)
let date = NSDate()
let calendar = NSCalendar.currentCalendar()
let components = calendar.components([.Hour, .Minute], fromDate: date)
let hour = components.hour
let minutes = components.minute
答案 5 :(得分:21)
Swift 4
let dateFormatter : DateFormatter = DateFormatter()
// dateFormatter.dateFormat = "yyyy-MM-dd HH:mm:ss"
dateFormatter.dateFormat = "yyyy-MMM-dd HH:mm:ss"
let date = Date()
let dateString = dateFormatter.string(from: date)
let interval = date.timeIntervalSince1970
<强>输出强>
2018-May-01 10:41:31
答案 6 :(得分:11)
斯威夫特3:
static func currentTime() -> String {
let date = Date()
let calendar = Calendar.current
let hour = calendar.component(.hour, from: date)
let minutes = calendar.component(.minute, from: date)
return "\(hour):\(minutes)"
}
PS - 不确定问题的确切含义是将当前时间(和小时)作为日期时间,但希望上述内容应该足以解释这个问题。
答案 7 :(得分:7)
如果你只需要一天中的小时
let calendar = NSCalendar.currentCalendar()
var hour = calendar.component(.Hour,fromDate: NSDate())
答案 8 :(得分:7)
使用Swift 3和Swift 4,Foundation
提供了许多来自Date
对象的小时值的方法。根据您的需要,您可以选择其中一个以下四个Playground代码段。
Calendar
dateComponents(_:from:)
方法 Calendar
有一个名为dateComponents(_:from:)
的方法。 dateComponents(_:from:)
有以下声明:
func dateComponents(_ components: Set<Calendar.Component>, from date: Date) -> DateComponents
使用日历时区返回日期的所有日期组件。
用法:
import Foundation
let date = Date()
let dateComponents = Calendar.current.dateComponents([.hour], from: date)
let hour = dateComponents.hour
print(String(describing: hour)) // may print: Optional(13)
Calendar
component(_:from:)
方法 Calendar
有一个名为component(_:from:)
的方法。 component(_:from:)
有以下声明:
返回日期的一个组件的值。
func component(_ component: Calendar.Component, from date: Date) -> Int
用法:
import Foundation
let date = Date()
let hour = Calendar.current.component(.hour, from: date)
print(hour) // may print: 13
DateFormatter
dateFormat
属性 DateFormatter
有一个名为dateFormat
的属性。 dateFormat
有以下声明:
var dateFormat: String! { get set }
接收方使用的日期格式字符串。
用法:
import Foundation
let date = Date()
let dateFormatter = DateFormatter()
dateFormatter.dateFormat = "HH"
let hour = dateFormatter.string(from: date)
print(hour) // may print: 13
Dateformatter
setLocalizedDateFormatFromTemplate(_:)
方法 Dateformatter
有一个名为setLocalizedDateFormatFromTemplate(_:)
的方法。 setLocalizedDateFormatFromTemplate(_:)
有以下声明:
func setLocalizedDateFormatFromTemplate(_ dateFormatTemplate: String)
使用指定的接收器区域设置从模板设置日期格式。
用法:
import Foundation
let date = Date()
let dateFormatter = DateFormatter()
dateFormatter.setLocalizedDateFormatFromTemplate("HH")
let hour = dateFormatter.string(from: date)
print(hour) // may print: 13
答案 9 :(得分:6)
在Swift 3中,
let date = Date()
let calendar = Calendar.current()
let hour = calendar.component(.hour, from: date)
答案 10 :(得分:6)
//Date
let dateFormatter = DateFormatter()
dateFormatter.dateStyle = .medium
let dateString = "Current date is: \(dateFormatter.string(from: Date() as Date))"
labelfordate.text = String(dateString)
//Time
let timeFormatter = DateFormatter()
timeFormatter.timeStyle = .medium
let timeString = "Current time is: \(timeFormatter.string(from: Date() as Date))"
labelfortime.text = String(timeString)
override func viewDidLoad() {
super.viewDidLoad()
timer = Timer.scheduledTimer(timeInterval: 1, target: self, selector: #selector(DateAndTime.action), userInfo: nil, repeats: true)
}
func action()
{
//Date
let dateFormatter = DateFormatter()
dateFormatter.dateStyle = .medium
let dateString = "Current date is: \(dateFormatter.string(from: Date() as Date))"
labelfordate.text = String(dateString)
//Time
let timeFormatter = DateFormatter()
timeFormatter.timeStyle = .medium
let timeString = "Current time is: \(timeFormatter.string(from: Date() as Date))"
labelfortime.text = String(timeString)
}
注意:Timer代码中的 DateAndTime 是类名。
答案 11 :(得分:5)
我知道有很多答案,但我认为对我们来说可能更方便
extension String {
init(epoch: Double) {
let date = Date(timeIntervalSince1970: epoch)
let dateFormatter = DateFormatter()
dateFormatter.dateFormat = "dd/MM/yyyy HH:mm:ssZZZ"
self = dateFormatter.string(from: date)
}
}
答案 12 :(得分:4)
你可以试试这个
func getTime() -> (hour:Int, min:Int, sec:Int) {
let currentDateTime = NSDate()
let calendar = NSCalendar.currentCalendar()
let components = calendar.components([.Hour,.Minute,.Second], fromDate: currentDateTime)
let hour = components.hour
let min = components.minute
let sec = components.second
return (hour,min,sec)
}
现在调用该方法并以小时,分钟和秒<
接收日期 let currentTime = self.getTime()
print("Hour: \(currentTime.hour) Min: \(currentTime.min) Sec: \(currentTime.sec))")
答案 13 :(得分:2)
仅限特定格式的日期
let dateFormatter1 = NSDateFormatter()
dateFormatter1.dateStyle = .MediumStyle
dateFormatter1.timeStyle = .NoStyle
dateFormatter1.dateFormat = "dd-MM-yyyy"
let date = dateFormatter1.stringFromDate(NSDate())
答案 14 :(得分:2)
Xcode 8.2.1•Swift 3.0.2
extension Date {
var hour: Int { return Calendar.autoupdatingCurrent.component(.hour, from: self) }
}
let date = Date() // "Mar 16, 2017, 3:43 PM"
let hour = date.hour // 15
答案 15 :(得分:1)
一行 Swift 5.2
let date = String(DateFormatter.localizedString(from:NSDate()as Date,dateStyle:.medium,timeStyle:.short))
答案 16 :(得分:1)
您可以在Date
上创建扩展程序,这样您就可以轻松地在其他文件中调用它。以下是使用计算属性的日期扩展的示例。
它将打印出来:“今天,下午4:55”
extension Date {
var formatter: DateFormatter? {
let formatter = DateFormatter()
formatter.dateStyle = .short
formatter.timeStyle = .short
formatter.doesRelativeDateFormatting = true
return formatter
}
}
答案 17 :(得分:1)
您可以使用Swift4或Swift 5波纹管,如下所示:
2020-03-02
输出如下:
{{1}}
答案 18 :(得分:1)
在noiiv's epically concise solution上展开,这是更简洁的Swift 3/4实现:
快速3/4
let components = Calendar.current.dateComponents([.hour, .minute], from: Date())
let (hour, minute) = (components.hour, components.minute)
此外,扩展到Leo Dabus's extension,我们可以得到:
extension Date {
func components(_ components: Set<Calendar.Component>) -> DateComponents {
return Calendar.current.dateComponents(components, from: self)
}
func component(_ component: Calendar.Component) -> Int {
return Calendar.current.component(component, from: self)
}
var era: Int { return component(.era) }
var year: Int { return component(.year) }
var month: Int { return component(.month) }
var day: Int { return component(.day) }
var hour: Int { return component(.hour) }
var minute: Int { return component(.minute) }
var second: Int { return component(.second) }
var weekday: Int { return component(.weekday) }
var weekdayOrdinal: Int { return component(.weekdayOrdinal) }
var quarter: Int { return component(.quarter) }
var weekOfMonth: Int { return component(.weekOfMonth) }
var weekOfYear: Int { return component(.weekOfYear) }
var yearForWeekOfYear: Int { return component(.yearForWeekOfYear) }
var nanosecond: Int { return component(.nanosecond) }
var calendar: Calendar? { return components([.calendar]).calendar }
var timeZone: TimeZone? { return components([.timeZone]).timeZone }
}
并像这样使用它:
let date = Date()
let (hour, minute) = (date.hour, date.minute)
答案 19 :(得分:0)
SWIFT 4:
// Test round
function playRound(playerSelection, computerSelection) {
if (playerSelection == computerSelection) {
return 'It\'s a tie!';
}
if (playerSelection == 'Rock') {
if (computerSelection == 'Paper') {
return 'Paper beats Rock, you lose!'
} else if (computerSelection == 'Scissors') {
return 'Rock beats Scissors, you win!'
}
}
答案 20 :(得分:0)
如果您需要以特定方式设置答案格式,则可以轻松使用此方法,默认=“ dd-MM-yyyy”。
extension Date {
func today(format : String = "dd-MM-yyyy") -> String{
let date = Date()
let formatter = DateFormatter()
formatter.dateFormat = format
return formatter.string(from: date)
}
}
现在可以使用
获取今天的日期Date().today() or Date().today("dd/MM/yyyy")
答案 21 :(得分:0)
func getCurrentDate() -> Date {
let date = Date()
let dateFormatter = DateFormatter()
dateFormatter.dateFormat = "yyyy-MM-dd"
let dateInString = dateFormatter.string(from: date)
let dateinDate = dateFormatter.date(from: dateInString)
return dateinDate!
}
答案 22 :(得分:0)
与Swift 5(Xcode 10和Xcode 11)配合使用(来自法国UTC)
func getCurrentDateTime() {
let now = Date()
let formatter = DateFormatter()
formatter.locale = Locale(identifier: "fr_FR")
formatter.dateFormat = "EEEE dd MMMM YYYY HH:mm"
myLabel.text = formatter.string(from: now)
myLabel.font = UIFont(name: "HelveticaNeue-Light", size: 12)
myLabel.textColor = UIColor.black
}
如果只想显示日期,请设置formatter.dateFormat
formatter.dateFormat = "EEEE dd MMMM YYYY"
要仅显示小时数,请将formatter.dateFormat
更改为
formatter.dateFormat = "HH:mm"
不要忘记在getCurrentDateTime()
上添加viewDidLoad
。
答案 23 :(得分:0)
雨燕5
func printTimestamp() {
let timestamp = DateFormatter.localizedString(from: NSDate() as Date, dateStyle: .medium, timeStyle: .short)
print(timestamp)
}
和调用函数printTimestamp()
答案 24 :(得分:0)
您可以像波纹管一样在Swift 5中使用
let date = Date()
let df = DateFormatter()
df.dateFormat = "yyyy-MM-dd HH:mm:ss"
let dateString = df.string(from: date)
输出就像波纹管一样
2019-12-20 09:40:08
答案 25 :(得分:0)
这是 SWIFT 扩展名,用于获取您当前的设备位置时间(GMT)。
func getGMTTimeDate() -> Date {
var comp: DateComponents = Calendar.current.dateComponents([.year, .month, .day, .hour, .minute], from: self)
comp.calendar = Calendar.current
comp.timeZone = TimeZone(abbreviation: "GMT")!
return Calendar.current.date(from: comp)!
}
现在获取时间:-
Date().getGMTTimeDate()
答案 26 :(得分:0)
您可以从Dateformatter
获取let dateFormatter = DateFormatter()
dateFormatter.dateFormat = "dd/MM/yyyy"
let dateString = dateFormatter.string(from:Date())
print(dateString)
答案 27 :(得分:-2)
以下代码是最新的 swift 版本 (5):
func getTimestamp()-> String {
let timestamp = DateFormatter.localizedString(from: Date(), dateStyle: .medium, timeStyle: .short)
return "\(timestamp)"
}