2 回答

TA貢獻1780條經驗 獲得超4個贊
是的,使用映射而不是數組,因此查找更快更直接:
var daysOfWeek = map[string]time.Weekday{
? ? "Sunday":? ? time.Sunday,
? ? "Monday":? ? time.Monday,
? ? "Tuesday":? ?time.Tuesday,
? ? "Wednesday": time.Wednesday,
? ? "Thursday":? time.Thursday,
? ? "Friday":? ? time.Friday,
? ? "Saturday":? time.Saturday,
}
func parseWeekday(v string) (time.Weekday, error) {
? ? if d, ok := daysOfWeek[v]; ok {
? ? ? ? return d, nil
? ? }
? ? return time.Sunday, fmt.Errorf("invalid weekday '%s'", v)
}
測試它:
fmt.Println(parseWeekday("Monday"))
fmt.Println(parseWeekday("Friday"))
fmt.Println(parseWeekday("invalid"))
輸出(在Go Playgorund上試試):
Monday <nil>
Friday <nil>
Sunday invalid weekday 'invalid'
提示:
您甚至可以使用for循環來安全地初始化daysOfWeek地圖,如下所示:
var daysOfWeek = map[string]time.Weekday{}
func init() {
? ? for d := time.Sunday; d <= time.Saturday; d++ {
? ? ? ? daysOfWeek[d.String()] = d
? ? }
}
測試和輸出是一樣的。在Go Playground試試這個。
這個地圖解決方案的另一個不錯的屬性(與您的數組解決方案相比)是您可以在同一個地圖中列出其他有效值,這些值可以在time.Weekday沒有額外解析代碼的情況下被解析成。
例如,讓我們也將 3 個字母的短工作日名稱解析為它們的time.Weekday等價物,例如"Mon"to time.Monday。
這個擴展可以用一個簡單的循環來添加:
var daysOfWeek = map[string]time.Weekday{}
func init() {
? ? for d := time.Sunday; d <= time.Saturday; d++ {
? ? ? ? name := d.String()
? ? ? ? daysOfWeek[name] = d
? ? ? ? daysOfWeek[name[:3]] = d
? ? }
}
測試它:
fmt.Println(parseWeekday("Monday"))
fmt.Println(parseWeekday("Friday"))
fmt.Println(parseWeekday("Mon"))
fmt.Println(parseWeekday("Fri"))
fmt.Println(parseWeekday("invalid"))
輸出(在Go Playground上嘗試):
Monday <nil>
Friday <nil>
Monday <nil>
Friday <nil>
Sunday invalid weekday 'invalid'

TA貢獻2065條經驗 獲得超14個贊
這看起來是這樣做的:
package main
import "time"
func parseWeekday(v string) (time.Weekday, error) {
t, e := time.Parse("Monday 2", v + " 2")
if e != nil { return 0, e }
return t.Weekday(), nil
}
func main() {
n, e := parseWeekday("Sunday")
if e != nil {
panic(e)
}
println(n == time.Sunday)
}
https://golang.org/pkg/time#Parse
- 2 回答
- 0 關注
- 127 瀏覽
添加回答
舉報