Go provides extensive support for formatting and parsing time through the time
package. This snippet demonstrates how to format time in different ways efficiently.
Basic Time Formatting
In Go, time is formatted using reference time Mon Jan 2 15:04:05 MST 2006
, and you replace each component as needed. Here's a straightforward example:
package main
import (
"fmt"
"time"
)
func main() {
currentTime := time.Now()
// Format time as a standard string.
formattedTime := currentTime.Format("2006-01-02 15:04:05")
fmt.Println("Formatted Time:", formattedTime)
// Custom format with day and month names.
customFormat := "Monday, 02-Jan-06 15:04:05 MST"
formattedTimeWithNames := currentTime.Format(customFormat)
fmt.Println("Custom Formatted Time:", formattedTimeWithNames)
}
Using Predefined Formats
The time
package provides predefined constants for common date and time formats:
package main
import (
"fmt"
"time"
)
func main() {
currentTime := time.Now()
// Use predefined formats.
rfc3339 := currentTime.Format(time.RFC3339)
ansic := currentTime.Format(time.ANSIC)
rfc1123 := currentTime.Format(time.RFC1123)
fmt.Println("RFC3339 Format:", rfc3339)
fmt.Println("ANSIC Format:", ansic)
fmt.Println("RFC1123 Format:", rfc1123)
}
Parsing a Time String
To turn a string into a time.Time
object, use the time.Parse
method with the appropriate format:
package main
import (
"fmt"
"time"
)
func main() {
timeString := "2023-10-26 19:30:00"
format := "2006-01-02 15:04:05"
parsedTime, err := time.Parse(format, timeString)
if err != nil {
fmt.Println("Error parsing time:", err)
return
}
fmt.Println("Parsed Time:", parsedTime)
}
Best Practices
- Understand Go's reference time
2006-01-02 15:04:05
for formatting properly. - Use predefined constants for common formats to reduce errors and improve readability.
- Always check for errors when parsing time to handle invalid input gracefully.
- Be mindful of time zones when formatting and parsing times, especially when dealing with internationalization.
Common Pitfalls
- Misunderstanding Go's reference time format can lead to incorrect formatting strings.
- Forgetting to handle parsing errors can cause unexpected runtime behavior.
- Ignoring time zones can lead to inconsistent time representations.
- Using
string
concatenation instead oftime
package methods for time formatting might not handle formatting specifiers correctly.
Performance Tips
- Reuse the same
Location
object if you need to convert time zones frequently. - If performance is critical, avoid unnecessary parsing and formatting of time, especially in tight loops.
- Consider using maps to cache frequently used time formats if they are computationally expensive to format.