Mercurial > mercurial > hgweb_golang.cgi
annotate src/entai/entai.go @ 55:4877160411cc
bug fix.
| author | pyon@macmini |
|---|---|
| date | Sat, 27 Jun 2020 16:19:45 +0900 |
| parents | e4066309b04f |
| children |
| rev | line source |
|---|---|
| 0 | 1 /****************************************************************************/ |
|
3
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
2 /* Entai.go ( ver 0.3 ) */ |
| 5 | 3 /* Last Change: 2016-10-22 Sat 15:06:28. */ |
|
3
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
4 /* By T.Mutoh */ |
| 0 | 5 /****************************************************************************/ |
| 6 | |
| 7 package entai | |
| 8 | |
| 9 import ( | |
| 10 "fmt" | |
|
3
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
11 "strconv" |
| 0 | 12 "time" |
| 13 ) | |
| 14 | |
| 15 var rate0s, rate1s []float64 | |
| 16 var nyds []time.Time | |
| 17 | |
| 18 type Entai struct { | |
| 19 tax int // 税額 | |
| 20 ed int // 経過日数 | |
| 21 yd0 []int // 各年の 1カ月以内の日数 | |
| 22 yd1 []int // 各年の 1カ月超えの日数 | |
| 23 | |
| 24 due time.Time | |
| 25 paid time.Time | |
| 26 am time.Time | |
| 27 } | |
| 28 | |
| 29 func init() { | |
|
3
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
30 } |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
31 |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
32 func ( e *Entai ) DefaultRates() { |
| 0 | 33 // 1カ月まで, 1カ月経過後, 元旦 |
| 34 createRates( 4.3, 14.6, "20120101" ) // H24 | |
| 35 createRates( 4.3, 14.6, "20130101" ) // H25 | |
| 4 | 36 createRates( 2.9, 9.2, "20140101" ) // H26 |
| 37 createRates( 2.8, 9.1, "20150101" ) // H27 | |
| 0 | 38 createRates( 2.8, 9.1, "20160101" ) // H28 |
| 2 | 39 createRates( 2.8, 9.1, "20170101" ) // H29 ***** |
|
3
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
40 |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
41 for range nyds { |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
42 e.yd0 = append( e.yd0, 0 ) |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
43 e.yd1 = append( e.yd1, 0 ) |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
44 } |
| 0 | 45 } |
| 46 | |
| 2 | 47 func createRates( r0, r1 float64, nyd string ) { |
| 48 t, _ := time.Parse( "20060102", nyd ) | |
| 0 | 49 rate0s = append( rate0s, r0 / 100 ) |
| 50 rate1s = append( rate1s, r1 / 100 ) | |
| 51 nyds = append( nyds, t ) | |
| 52 } | |
| 53 | |
|
3
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
54 func ( e *Entai ) AddRates( nyd, r0, r1 string ) error { |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
55 rf0, err := strconv.ParseFloat( r0, 64 ); if err != nil { |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
56 return err |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
57 } |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
58 rf1, err := strconv.ParseFloat( r1, 64 ); if err != nil { |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
59 return err |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
60 } |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
61 createRates( rf0, rf1, nyd ) |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
62 e.yd0 = append( e.yd0, 0 ) |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
63 e.yd1 = append( e.yd1, 0 ) |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
64 return nil |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
65 } |
|
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
66 |
| 0 | 67 func ( e Entai ) String() string { |
| 68 return "Entai....." | |
| 69 } | |
| 70 | |
| 5 | 71 func ( e Entai ) GetRates() ( str string ) { |
| 0 | 72 for i, n := range nyds { |
| 73 str += fmt.Sprintf( " (H%d) ", n.Year() - 1988 ) | |
| 74 str += fmt.Sprintf( "%s :%4.1f / %4.1f\n", n.Format("2006.01.02"), rate0s[i] * 100, rate1s[i] * 100 ) | |
| 75 } | |
| 76 return str | |
| 77 } | |
| 78 | |
| 79 func ( e *Entai ) countDays() { | |
| 80 | |
| 2 | 81 for i, _ := range nyds { |
| 82 e.yd0[i] = 0 | |
| 83 e.yd1[i] = 0 | |
| 0 | 84 } |
| 85 | |
| 86 // 1カ月後の算出 | |
| 87 for tmp := e.due; ; { | |
| 88 tmp = tmp.AddDate( 0, 0, 1 ) | |
| 89 for i, nyd := range nyds { | |
| 90 if tmp.Year() == nyd.Year() { | |
| 91 e.yd0[i]++ | |
| 92 } | |
| 93 } | |
| 94 if tmp.Day() == e.due.Day() { | |
| 95 e.am = tmp | |
| 96 break | |
| 97 } | |
| 2 | 98 if tmp == e.due.AddDate( 0, 1, 0 ) { |
| 99 tmp = tmp.AddDate( 0, 0, -1 ) | |
| 100 e.am = tmp | |
| 101 break | |
| 102 } | |
| 0 | 103 } |
| 104 | |
| 105 // 過ぎた日数の算出 | |
| 106 for i := 1; ; i++ { | |
| 107 tmp := e.due.AddDate( 0, 0, i ) | |
| 108 for j, nyd := range nyds { | |
| 109 if tmp.Year() == nyd.Year() { | |
| 110 e.yd1[j]++ | |
| 111 } | |
| 112 } | |
| 113 if e.paid.Sub( tmp ) == 0 { | |
| 114 for j, _ := range nyds { | |
| 115 e.yd1[j] -= e.yd0[j] | |
| 116 } | |
| 4 | 117 e.ed = i |
| 118 //e.yd1[len(e.yd1)-1]-- // コメントアウト:最終日を参入しない | |
| 119 //e.ed-- // 同上 | |
| 0 | 120 break |
| 121 } | |
| 122 } | |
| 123 } | |
| 124 | |
| 125 func ( e *Entai ) Set( d, p time.Time, g int ) { | |
| 126 e.due, e.paid = d, p | |
| 127 e.tax = g | |
| 128 e.countDays() | |
| 129 } | |
| 130 | |
| 131 func ( e *Entai ) Result() ( int, string ) { | |
| 132 | |
| 133 /* 税額の前処理 */ | |
| 134 if e.tax < 2000 { | |
| 135 return 0, "tax < 2000" | |
| 136 } | |
|
3
ca866a38a6a0
Implement intaractive-mode & setting from config-file.
pyon@macmini
parents:
2
diff
changeset
|
137 e.tax = int( e.tax / 1000 ) * 1000 // 端数処理 |
| 0 | 138 |
| 139 /* 本計算 */ | |
| 140 var tmp float64 | |
| 141 for i, _ := range nyds { | |
| 2 | 142 tmp += float64( e.yd0[i] ) * rate0s[i] + float64( e.yd1[i] ) * rate1s[i] |
| 0 | 143 } |
| 2 | 144 tmp *= float64( e.tax ) / 365.0 |
| 0 | 145 |
| 146 /* 利息の後処理&端数処理 */ | |
| 147 var intrst int | |
| 148 if tmp < 1000 { | |
| 149 intrst = 0 | |
| 150 } else { | |
| 151 intrst = int( tmp / 100 ) * 100 | |
| 152 } | |
| 153 | |
| 154 /* 追加情報 */ | |
| 2 | 155 detail := fmt.Sprintf( "%d,%.0f,%d =", e.tax, tmp, e.ed ) |
| 0 | 156 for i, _ := range nyds { |
| 2 | 157 tmp1 := float64( e.yd0[i] ) * rate0s[i] * float64( e.tax ) / 365.0 |
| 158 tmp2 := float64( e.yd1[i] ) * rate1s[i] * float64( e.tax ) / 365.0 | |
| 4 | 159 detail += fmt.Sprintf( ": %d %d (%.1f+%.1f=%.1f)", e.yd0[i], e.yd1[i], tmp1, tmp2, tmp1 + tmp2 ) |
| 0 | 160 } |
| 161 | |
| 2 | 162 return intrst, detail |
| 0 | 163 } |
| 164 |
