-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.Rmd
156 lines (108 loc) · 6.13 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# jcalendaR
<!-- badges: start -->
<!-- badges: end -->
**English version of README is not available for now.**
`jcalendaR`はRで和暦と旧暦、西暦(ユリウス暦、(先発)グレゴリウス暦)の年月日を相互変換を行うためのパッケージです。
## 機能
* 和暦から西暦(ユリウス暦、(先発)グレゴリウス暦)への変換ができます。
* 旧暦から西暦(ユリウス暦、(先発)グレゴリウス暦)への変換ができます。
* 西暦(ユリウス暦、(先発)グレゴリウス暦)から和暦への変換ができます。
* 西暦(ユリウス暦、(先発)グレゴリウス暦)から旧暦への変換ができます。
* 年号を付与しない場合は旧暦は1年1月1日(先発グレゴリオ暦1年2月10日)から2100年12月1日(グレゴリウス暦2100年12月31日)までしか対応していません。
* それ以前または以後の年月日を入力すると警告文とともにNAを出力するか、計算できないか、変な値を返します。
* 年号は、景行天皇以降(旧暦17年以降)の元号に対応してています。
* 旧字体(例えば慶應など)には対応していません。
* 元号について、現在のところ西暦から和暦・旧暦への変換時に付与する元号は改元した日以降で付与され、改元の年始は前の元号で出力されます。つまり、明治以前でみられる改元したとしの年始にさかのぼって改元が適応される形式には西暦からの変換の場合は対応していません。
* 和暦・旧暦から西暦への変換の場合は改元された年の年始からその元年として扱えます。
* 和暦・旧暦から西暦への変換の場合はその年号が改元されずに続いた場合の年数でも計算できます。
* 現在以降の年月日については現在の元号が続いていくものとみなして出力します。
* 過去の元号について、南朝だけでなく指定することで北朝、平家、京都、関東地方で使用されていた元号で対照することもできます。
* 旧暦の閏月は「閏」と「うるう」の両方の表記をサポートします。
* 改元の最初の年は「元年」と「1年」の両方の表記をサポートします。
* 和暦と旧暦は明治5年以前は一致します。
* 旧暦の暦法および、元号の表記および改元日は参照元データによるものです。
* 内部的に、ユリウス通日を計算しています。
* 西暦から(修正)ユリウス通日、(修正)ユリウス通日から西暦へ変換する関数もあります。
## Installation
リリース版はCRANからインストールできます。
```r
install.package("jcalendaR")
```
開発版はGithubからインストールできます。
```r
remotes::install_github("indenkun/jcalendaR")
```
## Example
```{r example}
library(jcalendaR)
```
### 和暦と西暦
```{r}
wareki2seireki("令和3年1月1日")
seireki2wareki("2021/1/1")
wareki2seireki("天正6年3月13日", calendar = "julian")
seireki2wareki("1578/4/18")
```
### 旧暦と西暦
```{r}
kyureki2seireki("令和3年1月1日")
seireki2kyureki("2021/1/1")
```
### 和暦と旧暦
```{r}
wareki2kyureki("令和3年1月1日")
kyureki2wareki("令和2年11月18日")
```
### utils
旧暦の指定した年に閏月があるかどうか、理論型か閏月の値で答えます。
指定する年の値は年号と数字で構成される必要があります。数字の後ろに年がついているかどうかは問いません。
```{r}
existence_leap.month("明治2")
existence_leap.month("明治2", existence = "number")
existence_leap.month("明治3年", existence = "logical")
existence_leap.month("明治3年", existence = "number")
```
旧暦の指定した年の指定した月が何日あるか。閏月を指定した場合、その年に閏月がないならその旨を警告文で出します。
指定する年の値は年号と数字で構成される必要があります。数字の後ろに年がついているかどうかは問いません。
また、指定する月は数値または文字列で、文字列の場合に数字の後ろに月がついているかどうかは問いません。
```{r, error = TRUE}
number_kyureki.month("明治2", 1)
number_kyureki.month("明治2年", "閏1")
number_kyureki.month("明治3", "閏10月")
```
### ユリウス通日と西暦
```{r}
jdn2calendar(2459216)
calendar2jdn("2021/1/1")
```
### 警告文が出力されるパターン
```{r, error = TRUE}
seireki2wareki("1/1/1")
wareki2seireki("天保2年2月30日")
wareki2seireki("0年1月1日", era = "non")
kyureki2seireki("2101年1月1日", era = "non")
```
# 参照
ユリウス通日の計算には[ユリウス通日 - Wikipedia](https://ja.wikipedia.org/wiki/ユリウス通日)の式を用いています。
# 参照元データ
グレゴリウス暦と旧暦の対照表、元号について以下のデータを参照しました。
* [manakai/data-locale](https://github.com/manakai/data-locale)
# Known Issues and Future Tasks
* 関数製作者は暦についての専門家ではありません。なにか不備があればお知らせください。
* 参照元データの典拠である日本暦日原典の対照表が、どの暦法を元にしているのか分かっていません。単にデータだけを利用しています。詳細はデータの参照元のドキュメントの[https://github.com/manakai/data-locale/blob/master/doc/calendar-kyuureki.txt](https://github.com/manakai/data-locale/blob/master/doc/calendar-kyuureki.txt)を参照してください。
* 不適切な値が入力された場合に警告文を表示しNAを出力する場合と処理が完了しない警告があり、統一されていません。
* 琉球暦未対応。
# License
MIT