koyomi -- 日本のこよみ
Migrated repository to github.com/goark/koyomi
「国立天文台 天文情報センター 暦計算室」より日本の暦情報を取得する Go 言語用パッケージです。 Google Calendar を経由して取得しています。
取得可能な情報は以下の通りです。
const (
Holiday CalendarID = iota + 1 //国民の祝日および休日
MoonPhase //朔弦望
SolarTerm //二十四節気・雑節
Eclipse //日食・月食・日面経過
Planet //惑星現象
)
package main
import (
"bytes"
"io"
"os"
"time"
"github.com/goark/koyomi"
"github.com/goark/koyomi/value"
)
func main() {
start, _ := value.DateFrom("2019-05-01")
end := value.NewDate(time.Date(2019, time.May, 31, 0, 0, 0, 0, value.JST))
td, err := os.MkdirTemp(os.TempDir(), "sample")
if err != nil {
return
}
defer func() { _ = os.RemoveAll(td) }()
k, err := koyomi.NewSource(
koyomi.WithCalendarID(koyomi.Holiday, koyomi.SolarTerm),
koyomi.WithStartDate(start),
koyomi.WithEndDate(end),
koyomi.WithTempDir(td),
).Get()
if err != nil {
return
}
csv, err := k.EncodeCSV()
if err != nil {
return
}
io.Copy(os.Stdout, bytes.NewReader(csv))
}
package main
import (
"os"
"text/template"
"time"
"github.com/goark/koyomi"
"github.com/goark/koyomi/value"
)
func main() {
start, _ := value.DateFrom("2019-05-01")
end := value.NewDate(time.Date(2019, time.May, 31, 0, 0, 0, 0, value.JST))
td, err := os.MkdirTemp(os.TempDir(), "sample")
if err != nil {
return
}
defer func() { _ = os.RemoveAll(td) }()
k, err := koyomi.NewSource(
koyomi.WithCalendarID(koyomi.Holiday, koyomi.SolarTerm),
koyomi.WithStartDate(start),
koyomi.WithEndDate(end),
koyomi.WithTempDir(td),
).Get()
if err != nil {
return
}
myTemplate := `| 日付 | 曜日 | 内容 |
| ---- |:----:| ---- |
{{ range . }}| {{ .Date.StringJp }} | {{ .Date.WeekdayJp.ShortStringJp }} | {{ .Title }} |
{{ end -}}`
t, err := template.New("").Parse(myTemplate)
if err != nil {
return
}
if err := t.Execute(os.Stdout, k.Events()); err != nil {
return
}
//Output:
//| 日付 | 曜日 | 内容 |
//| ---- |:----:| ---- |
//| 2019年5月1日 | 水 | 休日 (天皇の即位の日) |
//| 2019年5月2日 | 木 | 休日 |
//| 2019年5月2日 | 木 | 八十八夜 |
//| 2019年5月3日 | 金 | 憲法記念日 |
//| 2019年5月4日 | 土 | みどりの日 |
//| 2019年5月5日 | 日 | こどもの日 |
//| 2019年5月6日 | 月 | 休日 |
//| 2019年5月6日 | 月 | 立夏 |
//| 2019年5月21日 | 火 | 小満 |
}
元号を含む和暦と西暦との変換を行います。 元号は以下のものに対応しています(グレゴリオ暦採用以降)。
元号 | 起点 |
---|---|
明治(改暦以降) | 1873年1月1日 |
大正 | 1912年7月30日 |
昭和 | 1926年12月25日 |
平成 | 1989年1月8日 |
令和 | 2019年5月1日 |
package main
import (
"flag"
"fmt"
"os"
"strconv"
"time"
"github.com/goark/koyomi/value"
)
func main() {
flag.Parse()
argsStr := flag.Args()
tm := time.Now()
if len(argsStr) > 0 {
if len(argsStr) < 3 {
fmt.Fprintln(os.Stderr, "年月日を指定してください")
return
}
args := make([]int, 3)
for i := 0; i < 3; i++ {
num, err := strconv.Atoi(argsStr[i])
if err != nil {
fmt.Fprintln(os.Stderr, err)
return
}
args[i] = num
}
tm = time.Date(args[0], time.Month(args[1]), args[2], 0, 0, 0, 0, time.Local)
}
te := value.NewDate(tm)
n, y := te.YearEraString()
if len(n) == 0 {
fmt.Fprintln(os.Stderr, "正しい年月日を指定してください")
return
}
fmt.Printf("%s%s%d月%d日\n", n, y, te.Month(), te.Day())
}
これを実行すると以下のような結果になります。
$ go run sample/sample1.go 2019 4 30
平成31年4月30日
$ go run sample/sample1.go 2019 5 1
令和元年5月1日
package main
import (
"flag"
"fmt"
"os"
"strconv"
"time"
"github.com/goark/koyomi/value"
)
func main() {
flag.Parse()
argsStr := flag.Args()
if len(argsStr) < 4 {
fmt.Fprintln(os.Stderr, "元号 年 月 日 を指定してください")
return
}
name := argsStr[0]
args := make([]int, 3)
for i := 0; i < 3; i++ {
num, err := strconv.Atoi(argsStr[i+1])
if err != nil {
fmt.Fprintln(os.Stderr, err)
return
}
args[i] = num
}
te := value.NewDateEra(value.EraName(name), args[0], time.Month(args[1]), args[2])
fmt.Println(te.Format("西暦2006年1月2日"))
}
これを実行すると以下のような結果になります。
$ go run sample/sample2.go 平成 31 4 30
西暦2019年4月30日
$ go run sample/sample2.go 令和 1 5 1
西暦2019年5月1日
$ go run sample/sample2.go 昭和 100 1 1
西暦2025年1月1日
package main
import (
"flag"
"fmt"
"os"
"github.com/goark/koyomi/value"
"github.com/goark/koyomi/zodiac"
)
func main() {
flag.Parse()
args := flag.Args()
if len(args) < 1 {
fmt.Fprintln(os.Stderr, os.ErrInvalid)
return
}
for _, s := range args {
t, err := value.DateFrom(s)
if err != nil {
fmt.Fprintln(os.Stderr, err)
continue
}
kan, shi := zodiac.ZodiacYearNumber(t.Year())
fmt.Printf("Year %v is %v%v (Eho: %v)\n", t.Year(), kan, shi, kan.DirectionJp())
kan, shi = zodiac.ZodiacDayNumber(t)
fmt.Printf("Day %v is %v%v\n", t.Format("2006-01-02"), kan, shi)
}
}
これを実行すると以下のような結果になります。
$ go run sample/sample3.go 2021-07-28
Year 2021 is 辛丑 (Eho: 南南東微南)
Day 2021-07-28 is 丁丑
package main
import (
"flag"
"fmt"
"os"
"github.com/goark/koyomi/jdn"
"github.com/goark/koyomi/value"
)
func main() {
flag.Parse()
args := flag.Args()
if len(args) < 1 {
fmt.Fprintln(os.Stderr, os.ErrInvalid)
return
}
for _, s := range args {
t, err := value.DateFrom(s)
if err != nil {
fmt.Fprintln(os.Stderr, err)
continue
}
j := jdn.GetJDN(t.Time)
fmt.Printf("Julian Day Number of %v is %v\n", t.Format("2006-01-02"), j)
}
}
これを実行すると以下のような結果になります。
$ go run sample/sample4.go 2023-02-25
Julian Day Number of 2023-02-25 is 2460000