base_from_eia_steo.go 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. package models
  2. import (
  3. "eta/eta_crawler/utils"
  4. "time"
  5. "github.com/beego/beego/v2/client/orm"
  6. "github.com/shopspring/decimal"
  7. )
  8. // BaseFromEiaSteoIndex EiaSteo指标
  9. type BaseFromEiaSteoIndex struct {
  10. BaseFromEiaSteoIndexId int `orm:"column(base_from_eia_steo_index_id);pk"`
  11. BaseFromEiaSteoClassifyId int `description:"指标分类id"`
  12. IndexCode string `description:"指标编码"`
  13. IndexName string `description:"指标名称(中文名称)"`
  14. IndexNameOriginal string `description:"指标名称(原始名称)"`
  15. Frequency string `description:"频度"`
  16. Level int `description:"指标层级(原始层级)"`
  17. Unit string `description:"单位"`
  18. Super string `description:"我也不知道是个啥,反正先存起来,万一用到了呢"`
  19. Precision int `description:"精度,我也不知道会不会用到,反正先存起来,万一用到了呢"`
  20. LastHistorical string `description:"最近的历史记录,我也不知道会不会用到,反正先存起来,万一用到了呢"`
  21. Description string `description:"备注信息,我也不知道会不会用到,反正先存起来,万一用到了呢"`
  22. IsMappable int `description:"是否可映射,我也不知道会不会用到,反正先存起来,万一用到了呢"`
  23. StartDate time.Time `description:"开始日期"`
  24. EndDate time.Time `description:"结束日期"`
  25. ModifyTime time.Time `description:"最新更新时间"`
  26. CreateTime time.Time `description:"创建时间"`
  27. LatestValue float64 `description:"最新值"`
  28. }
  29. // Add 新增指标
  30. func (item *BaseFromEiaSteoIndex) Add() (err error) {
  31. o := orm.NewOrmUsingDB("data")
  32. lastId, err := o.Insert(item)
  33. if err != nil {
  34. return
  35. }
  36. item.BaseFromEiaSteoIndexId = int(lastId)
  37. return
  38. }
  39. // Update 更新作者基础信息
  40. func (item *BaseFromEiaSteoIndex) Update(cols []string) (err error) {
  41. o := orm.NewOrmUsingDB("data")
  42. _, err = o.Update(item, cols...)
  43. return
  44. }
  45. // BaseFromEiaSteoClassify EiaSteo分类
  46. type BaseFromEiaSteoClassify struct {
  47. BaseFromEiaSteoClassifyId int `orm:"column(base_from_eia_steo_classify_id);pk"`
  48. ClassifyName string `description:"分类名称(中文名称)"`
  49. ClassifyNameOriginal string `description:"分类名称(原始名称)"`
  50. ParentId int `description:"父级id"`
  51. Level int `description:"层级"`
  52. ModifyTime time.Time `description:"最新更新时间"`
  53. CreateTime time.Time `description:"创建时间"`
  54. }
  55. // 新增分类
  56. func (item *BaseFromEiaSteoClassify) AddBaseFromEiaSteoClassify() (err error) {
  57. o := orm.NewOrmUsingDB("data")
  58. lastId, err := o.Insert(item)
  59. if err != nil {
  60. return
  61. }
  62. item.BaseFromEiaSteoClassifyId = int(lastId)
  63. return
  64. }
  65. // BaseFromEiaSteoData EiaSteo数据表
  66. type BaseFromEiaSteoData struct {
  67. BaseFromEiaSteoDataId int `orm:"column(base_from_eia_steo_data_id);pk"`
  68. BaseFromEiaSteoIndexId int `description:"指标id"`
  69. IndexCode string `description:"指标编码"`
  70. DataTime time.Time `description:"数据日期"`
  71. Value float64 `description:"数据值"`
  72. ModifyTime time.Time `description:"最新更新时间"`
  73. CreateTime time.Time `description:"创建时间"`
  74. }
  75. // GetBaseFromEiaSteoClassifyAll 获取所有的分类
  76. func GetBaseFromEiaSteoClassifyAll() (list []*BaseFromEiaSteoClassify, err error) {
  77. o := orm.NewOrmUsingDB("data")
  78. sql := `SELECT * FROM base_from_eia_steo_classify`
  79. _, err = o.Raw(sql).QueryRows(&list)
  80. return
  81. }
  82. func GetChildBaseFromEiaSteoClassifyById(classifyId int) (list []*BaseFromEiaSteoClassify, err error) {
  83. o := orm.NewOrmUsingDB("data")
  84. sql := `SELECT * FROM base_from_eia_steo_classify WHERE parent_id = ?`
  85. _, err = o.Raw(sql, classifyId).QueryRows(&list)
  86. return
  87. }
  88. func GetBaseFromEiaSteoClassifyByName(classifyName string) (item *BaseFromEiaSteoClassify, err error) {
  89. o := orm.NewOrmUsingDB("data")
  90. sql := `SELECT * FROM base_from_eia_steo_classify WHERE classify_name = ?`
  91. err = o.Raw(sql, classifyName).QueryRow(&item)
  92. return
  93. }
  94. // GetBaseFromEiaSteoIndexAll 获取所有的指标
  95. func GetBaseFromEiaSteoIndexAll() (list []*BaseFromEiaSteoIndex, err error) {
  96. o := orm.NewOrmUsingDB("data")
  97. sql := `SELECT * FROM base_from_eia_steo_index`
  98. _, err = o.Raw(sql).QueryRows(&list)
  99. return
  100. }
  101. func lastDayOfMonth(year int, month time.Month) string {
  102. firstDay := time.Date(year, month, 1, 0, 0, 0, 0, time.Local)
  103. nextMonth := firstDay.AddDate(0, 1, 0)
  104. return nextMonth.Add(-time.Second * 1).Format(utils.FormatDate)
  105. }
  106. // HandleEiaSteoData 数据处理
  107. func HandleEiaSteoData(dataList map[string]interface{}, indexInfo *BaseFromEiaSteoIndex) (err error) {
  108. o := orm.NewOrmUsingDB("data")
  109. to, err := o.Begin()
  110. if err != nil {
  111. return
  112. }
  113. defer func() {
  114. if err != nil {
  115. to.Rollback()
  116. } else {
  117. to.Commit()
  118. }
  119. }()
  120. var existList []*BaseFromEiaSteoData
  121. sql := `SELECT * FROM base_from_eia_steo_data WHERE index_code = ? order by data_time asc`
  122. _, err = to.Raw(sql, indexInfo.IndexCode).QueryRows(&existList)
  123. if err != nil {
  124. return err
  125. }
  126. existMap := make(map[string]*BaseFromEiaSteoData)
  127. for _, v := range existList {
  128. // 产品要求每个月的最后一天,为了兼容之前每个月第一天的数据
  129. dateTime := lastDayOfMonth(v.DataTime.Year(), v.DataTime.Month())
  130. existMap[dateTime] = v
  131. }
  132. // 待添加的数据列表
  133. addBaseFromEiaSteoDataList := make([]*BaseFromEiaSteoData, 0)
  134. endDate := indexInfo.EndDate
  135. startDate := indexInfo.StartDate
  136. var latestValue float64
  137. for date, v := range dataList {
  138. // 实际数据
  139. val := v.(float64)
  140. valDecimal := decimal.NewFromFloat(val).Round(4)
  141. val, _ = valDecimal.Float64()
  142. currDate, tmpErr := time.ParseInLocation(utils.FormatMonthDateUnSpace, date, time.Local)
  143. if tmpErr != nil {
  144. err = tmpErr
  145. return
  146. }
  147. // 产品要求每个月的最后一天
  148. date = lastDayOfMonth(currDate.Year(), currDate.Month())
  149. currDate, _ = time.ParseInLocation(utils.FormatDate, date, time.Local)
  150. initDate := time.Date(2010, time.January, 1, 0, 0, 0, 0, time.Local)
  151. if currDate.Before(initDate) {
  152. continue
  153. }
  154. if currDate.After(endDate) {
  155. endDate = currDate
  156. latestValue = val
  157. } else if currDate.Equal(endDate) {
  158. // 修复历史数据
  159. latestValue = val
  160. }
  161. if currDate.Before(startDate) {
  162. startDate = currDate
  163. }
  164. // date = currDate.Format(utils.FormatDate)
  165. //fmt.Println("date:", date)
  166. tmpBaseFromEiaSteoData, ok := existMap[date]
  167. if !ok {
  168. addBaseFromEiaSteoDataList = append(addBaseFromEiaSteoDataList, &BaseFromEiaSteoData{
  169. //BaseFromEiaSteoDataId: 0,
  170. BaseFromEiaSteoIndexId: indexInfo.BaseFromEiaSteoIndexId,
  171. IndexCode: indexInfo.IndexCode,
  172. DataTime: currDate,
  173. Value: val,
  174. ModifyTime: time.Now(),
  175. CreateTime: time.Now(),
  176. })
  177. } else {
  178. nowVal := decimal.NewFromFloat(tmpBaseFromEiaSteoData.Value)
  179. //fmt.Println(date, "=========", nowVal.Equal(valDecimal))
  180. var updateCols []string
  181. if !nowVal.Equal(valDecimal) {
  182. tmpBaseFromEiaSteoData.Value = val
  183. tmpBaseFromEiaSteoData.ModifyTime = time.Now()
  184. updateCols = append(updateCols, "value")
  185. updateCols = append(updateCols, "modify_time")
  186. }
  187. if len(updateCols) > 0 {
  188. _, err = to.Update(tmpBaseFromEiaSteoData, updateCols...)
  189. if err != nil {
  190. return
  191. }
  192. }
  193. }
  194. delete(existMap, date)
  195. }
  196. lenAddBaseFromEiaSteoDataList := len(addBaseFromEiaSteoDataList)
  197. if lenAddBaseFromEiaSteoDataList > 0 {
  198. _, err = to.InsertMulti(lenAddBaseFromEiaSteoDataList, addBaseFromEiaSteoDataList)
  199. }
  200. existMapNum := len(existMap)
  201. if existMapNum > 0 {
  202. idList := make([]int, 0)
  203. for _, v := range existMap {
  204. idList = append(idList, v.BaseFromEiaSteoDataId)
  205. }
  206. sql = `DELETE FROM base_from_eia_steo_data WHERE base_from_eia_steo_data_id in(` + utils.GetOrmInReplace(existMapNum) + `) `
  207. _, err = to.Raw(sql, idList).Exec()
  208. if err != nil {
  209. return err
  210. }
  211. }
  212. // 更新指标信息
  213. {
  214. updateParams := make([]string, 0)
  215. indexInfo.ModifyTime = time.Now()
  216. indexInfo.LatestValue = latestValue
  217. updateParams = append(updateParams, "ModifyTime", "LatestValue")
  218. if endDate.After(indexInfo.EndDate) {
  219. indexInfo.EndDate = endDate
  220. updateParams = append(updateParams, "EndDate")
  221. }
  222. if startDate.Before(indexInfo.StartDate) {
  223. indexInfo.StartDate = startDate
  224. updateParams = append(updateParams, "StartDate")
  225. }
  226. _, err = to.Update(indexInfo, updateParams...)
  227. if err != nil {
  228. return
  229. }
  230. }
  231. return
  232. }