base_edb_lib.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529
  1. package data
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/models"
  5. "eta/eta_api/models/data_manage"
  6. "eta/eta_api/models/data_manage/response"
  7. "eta/eta_api/utils"
  8. "fmt"
  9. "io/ioutil"
  10. "net/http"
  11. "strings"
  12. )
  13. // AddEdbData 新增指标数据
  14. func AddEdbData(source int, edbCode string) (resp *models.BaseResponse, err error) {
  15. param := make(map[string]interface{})
  16. param["EdbCode"] = edbCode
  17. param["Source"] = source
  18. urlStr := ``
  19. switch source {
  20. case utils.DATA_SOURCE_THS:
  21. urlStr = "ths/add"
  22. case utils.DATA_SOURCE_WIND:
  23. urlStr = "wind/add"
  24. case utils.DATA_SOURCE_PB:
  25. urlStr = "pb/add"
  26. case utils.DATA_SOURCE_PB_FINANCE:
  27. urlStr = "pb_finance/add"
  28. case utils.DATA_SOURCE_MANUAL:
  29. urlStr = "manual/add"
  30. case utils.DATA_SOURCE_LZ:
  31. urlStr = "lz/add"
  32. case utils.DATA_SOURCE_YS:
  33. urlStr = "smm/add"
  34. case utils.DATA_SOURCE_GL:
  35. urlStr = "mysteel/add"
  36. case utils.DATA_SOURCE_ZZ:
  37. urlStr = "zz/add"
  38. case utils.DATA_SOURCE_DL:
  39. urlStr = "dl/add"
  40. case utils.DATA_SOURCE_SH:
  41. urlStr = "sh/add"
  42. case utils.DATA_SOURCE_CFFEX:
  43. urlStr = "cffex/add"
  44. case utils.DATA_SOURCE_SHFE:
  45. urlStr = "shfe/add"
  46. case utils.DATA_SOURCE_GIE:
  47. urlStr = "gie/add"
  48. case utils.DATA_SOURCE_LT:
  49. urlStr = "lt/add"
  50. case utils.DATA_SOURCE_COAL:
  51. urlStr = "coal/add"
  52. case utils.DATA_SOURCE_GOOGLE_TRAVEL:
  53. urlStr = "google_travel/add"
  54. case utils.DATA_SOURCE_MYSTEEL_CHEMICAL:
  55. urlStr = "mysteel_chemical/add"
  56. case utils.DATA_SOURCE_EIA_STEO:
  57. urlStr = "eia_steo/add"
  58. case utils.DATA_SOURCE_COM_TRADE:
  59. urlStr = "com_trade/add"
  60. case utils.DATA_SOURCE_SCI:
  61. urlStr = "sci/add"
  62. case utils.DATA_SOURCE_BAIINFO:
  63. urlStr = "baiinfo/add"
  64. case utils.DATA_SOURCE_NATIONAL_STATISTICS:
  65. urlStr = "national_statistics/add"
  66. case utils.DATA_SOURCE_FUBAO:
  67. urlStr = "fubao/add"
  68. case utils.DATA_SOURCE_GFEX:
  69. urlStr = "gz/add"
  70. case utils.DATA_SOURCE_ICPI:
  71. urlStr = "icpi/add"
  72. default:
  73. edbSource := data_manage.EdbSourceIdMap[source]
  74. if edbSource != nil {
  75. urlStr = edbSource.EdbAddMethod
  76. }
  77. }
  78. if urlStr == "" {
  79. err = fmt.Errorf("未实现该指标的刷新接口,请联系管理员")
  80. return
  81. }
  82. resp, err = postRefreshEdbData(param, urlStr)
  83. return
  84. }
  85. // AddEdbData 新增指标数据
  86. func AddEdbDataWindWsd(source int, stockCode, edbCode string) (resp *models.BaseResponse, err error) {
  87. param := make(map[string]interface{})
  88. param["EdbCode"] = edbCode
  89. param["StockCode"] = stockCode
  90. param["Source"] = source
  91. urlStr := `wind/wsd/add`
  92. if urlStr == "" {
  93. err = fmt.Errorf("未实现该指标的刷新接口,请联系管理员")
  94. return
  95. }
  96. resp, err = postRefreshEdbData(param, urlStr)
  97. return
  98. }
  99. // AddEdbDataThsDs 新增指标数据
  100. func AddEdbDataThsDs(source int, stockCode, edbCode string) (resp *models.BaseResponse, err error) {
  101. param := make(map[string]interface{})
  102. param["EdbCode"] = edbCode
  103. param["StockCode"] = stockCode
  104. param["Source"] = source
  105. urlStr := `ths/ds/add`
  106. if urlStr == "" {
  107. err = fmt.Errorf("未实现该指标的刷新接口,请联系管理员")
  108. return
  109. }
  110. resp, err = postRefreshEdbData(param, urlStr)
  111. return
  112. }
  113. type AddPredictEdbDataResponse struct {
  114. Ret int
  115. Msg string
  116. ErrMsg string
  117. ErrCode string
  118. Data data_manage.AddEdbInfoResp
  119. Success bool `description:"true 执行成功,false 执行失败"`
  120. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  121. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  122. }
  123. // EdbCalculateSaveMultiResponse 批量计算返回值
  124. type EdbCalculateSaveMultiResponse struct {
  125. Ret int
  126. Msg string
  127. ErrMsg string
  128. ErrCode string
  129. Data data_manage.BatchEdbInfoCalculateBatchSaveResp
  130. Success bool `description:"true 执行成功,false 执行失败"`
  131. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  132. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  133. }
  134. // SaveBasePredictEdbData 新增/编辑预测指标运算
  135. func SaveBasePredictEdbData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  136. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict/save")
  137. err = json.Unmarshal(resultByte, &resp)
  138. if err != nil {
  139. return
  140. }
  141. return
  142. }
  143. type PredictRuleCalculateByNineRespResponse struct {
  144. Ret int
  145. Msg string
  146. ErrMsg string
  147. ErrCode string
  148. Data response.PredictRuleCalculateByNineResp
  149. Success bool `description:"true 执行成功,false 执行失败"`
  150. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  151. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  152. }
  153. // PredictCalculateByNinePreview 预测指标动态环差演算
  154. func PredictCalculateByNinePreview(RuleConfigReqStr string) (resp *PredictRuleCalculateByNineRespResponse, err error) {
  155. _, resultByte, err := postAddEdbData(RuleConfigReqStr, "predict/calculate_by_nine/preview")
  156. err = json.Unmarshal(resultByte, &resp)
  157. if err != nil {
  158. return
  159. }
  160. return
  161. }
  162. // SavePredictEdbData 新增/编辑预测指标运算
  163. func SavePredictEdbData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  164. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/save")
  165. err = json.Unmarshal(resultByte, &resp)
  166. if err != nil {
  167. return
  168. }
  169. return
  170. }
  171. // BatchSavePredictEdbData 新增/编辑 预测指标运算(同比、同差)
  172. func BatchSavePredictEdbData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  173. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/batch/save")
  174. if err != nil {
  175. return
  176. }
  177. err = json.Unmarshal(resultByte, &resp)
  178. if err != nil {
  179. return
  180. }
  181. return
  182. }
  183. // RefreshEdbData 刷新指标数据
  184. func RefreshEdbData(edbInfoId, source, subSource int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  185. param := make(map[string]interface{})
  186. param["EdbCode"] = edbCode
  187. param["EdbInfoId"] = edbInfoId
  188. param["StartDate"] = startDate
  189. param["Source"] = source
  190. urlStr := ``
  191. switch source {
  192. case utils.DATA_SOURCE_THS:
  193. urlStr = "ths/refresh"
  194. if subSource == 0 {
  195. urlStr = "ths/refresh"
  196. } else {
  197. urlStr = "ths/ds/refresh"
  198. }
  199. case utils.DATA_SOURCE_WIND:
  200. if subSource == 0 {
  201. urlStr = "wind/refresh"
  202. } else {
  203. urlStr = "wind/wsd/refresh"
  204. }
  205. case utils.DATA_SOURCE_PB:
  206. urlStr = "pb/refresh"
  207. case utils.DATA_SOURCE_PB_FINANCE:
  208. urlStr = "pb_finance/refresh"
  209. case utils.DATA_SOURCE_MANUAL:
  210. urlStr = "manual/refresh"
  211. case utils.DATA_SOURCE_LZ:
  212. urlStr = "lz/refresh"
  213. case utils.DATA_SOURCE_YS:
  214. urlStr = "smm/refresh"
  215. case utils.DATA_SOURCE_GL:
  216. urlStr = "mysteel/refresh"
  217. case utils.DATA_SOURCE_ZZ:
  218. urlStr = "zz/refresh"
  219. case utils.DATA_SOURCE_DL:
  220. urlStr = "dl/refresh"
  221. case utils.DATA_SOURCE_SH:
  222. urlStr = "sh/refresh"
  223. case utils.DATA_SOURCE_CFFEX:
  224. urlStr = "cffex/refresh"
  225. case utils.DATA_SOURCE_SHFE:
  226. urlStr = "shfe/refresh"
  227. case utils.DATA_SOURCE_GIE:
  228. urlStr = "gie/refresh"
  229. case utils.DATA_SOURCE_LT:
  230. urlStr = "lt/refresh"
  231. case utils.DATA_SOURCE_COAL:
  232. urlStr = "coal/refresh"
  233. case utils.DATA_SOURCE_GOOGLE_TRAVEL:
  234. urlStr = "google_travel/refresh"
  235. case utils.DATA_SOURCE_MYSTEEL_CHEMICAL:
  236. urlStr = "mysteel_chemical/refresh"
  237. case utils.DATA_SOURCE_EIA_STEO:
  238. urlStr = "eia_steo/refresh"
  239. case utils.DATA_SOURCE_PREDICT:
  240. urlStr = "predict/refresh"
  241. case utils.DATA_SOURCE_COM_TRADE:
  242. urlStr = "com_trade/refresh"
  243. case utils.DATA_SOURCE_SCI:
  244. urlStr = "sci/refresh"
  245. case utils.DATA_SOURCE_BAIINFO:
  246. urlStr = "baiinfo/refresh"
  247. case utils.DATA_SOURCE_STOCK_PLANT:
  248. urlStr = "stock_plant/refresh"
  249. case utils.DATA_SOURCE_NATIONAL_STATISTICS:
  250. urlStr = "national_statistics/refresh"
  251. case utils.DATA_SOURCE_FUBAO:
  252. urlStr = "fubao/refresh"
  253. case utils.DATA_SOURCE_GFEX:
  254. urlStr = "gz/refresh"
  255. case utils.DATA_SOURCE_ICPI:
  256. urlStr = "icpi/refresh"
  257. default:
  258. edbSource := data_manage.EdbSourceIdMap[source]
  259. if edbSource != nil {
  260. urlStr = edbSource.EdbRefreshMethod
  261. }
  262. }
  263. if urlStr == "" {
  264. err = fmt.Errorf(fmt.Sprint("source:", source, ";未实现该指标的刷新接口,请联系管理员"))
  265. return
  266. }
  267. resp, err = postRefreshEdbData(param, urlStr)
  268. return
  269. }
  270. // RefreshEdbCalculateData 刷新普通计算指标数据请求
  271. func RefreshEdbCalculateData(edbInfoId int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  272. param := make(map[string]interface{})
  273. param["EdbCode"] = edbCode
  274. param["EdbInfoId"] = edbInfoId
  275. param["StartDate"] = startDate
  276. resp, err = postRefreshEdbData(param, "calculate/refresh")
  277. return
  278. }
  279. // RefreshPredictEdbCalculateData 刷新 预测计算指标 数据请求
  280. func RefreshPredictEdbCalculateData(edbInfoId int, edbCode, startDate string) (resp *models.BaseResponse, err error) {
  281. param := make(map[string]interface{})
  282. param["EdbCode"] = edbCode
  283. param["EdbInfoId"] = edbInfoId
  284. param["StartDate"] = startDate
  285. resp, err = postRefreshEdbData(param, "predict_calculate/refresh")
  286. return
  287. }
  288. // AddEdbCalculateData 新增 累计值转月-同比值-同差等计算新增
  289. func AddEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  290. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/add")
  291. err = json.Unmarshal(resultByte, &resp)
  292. if err != nil {
  293. return
  294. }
  295. return
  296. }
  297. // EditEdbCalculateData 编辑 累计值转月-同比值-同差等计算新增
  298. func EditEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  299. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/edit")
  300. err = json.Unmarshal(resultByte, &resp)
  301. if err != nil {
  302. return
  303. }
  304. return
  305. }
  306. // BatchSaveEdbCalculateData 新增 累计值转月-同比值-同差等计算新增
  307. func BatchSaveEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  308. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/save")
  309. err = json.Unmarshal(resultByte, &resp)
  310. if err != nil {
  311. return
  312. }
  313. return
  314. }
  315. // BatchEditEdbCalculateData 编辑 累计值转月-同比值-同差等计算新增
  316. func BatchEditEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *AddPredictEdbDataResponse, err error) {
  317. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/edit")
  318. err = json.Unmarshal(resultByte, &resp)
  319. if err != nil {
  320. return
  321. }
  322. return
  323. }
  324. // BatchSaveEdbCalculateMultiData 批量新增 累计值转月-同比值-同差等计算新增
  325. func BatchSaveEdbCalculateMultiData(edbInfoCalculateBatchSaveReqStr string) (resp *EdbCalculateSaveMultiResponse, err error) {
  326. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/save/multi")
  327. err = json.Unmarshal(resultByte, &resp)
  328. if err != nil {
  329. return
  330. }
  331. return
  332. }
  333. // BatchEditEdbCalculateMultiData 批量编辑 累计值转月-同比值-同差等计算新增
  334. func BatchEditEdbCalculateMultiData(edbInfoCalculateBatchSaveReqStr string) (resp *EdbCalculateSaveMultiResponse, err error) {
  335. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/batch/edit/multi")
  336. err = json.Unmarshal(resultByte, &resp)
  337. if err != nil {
  338. return
  339. }
  340. return
  341. }
  342. //// EditEdbCalculateData 修改计算指标数据请求
  343. //func EditEdbCalculateData(edbInfoCalculateBatchSaveReqStr string) (resp *models.BaseResponse, err error) {
  344. // resp, _, err = postAddEdbData(edbInfoCalculateBatchSaveReqStr, "batch/save")
  345. // return
  346. //}
  347. // ExecPythonCode 执行python代码
  348. func ExecPythonCode(pythonCode string) (resp *models.BaseResponse, err error) {
  349. param := make(map[string]interface{})
  350. param["PythonCode"] = pythonCode
  351. urlStr := `/python/exec`
  352. resp, err = postRefreshEdbData(param, urlStr)
  353. return
  354. }
  355. // AddPythonEdbData 新增python指标
  356. func AddPythonEdbData(param string) (resp *models.BaseResponse, err error) {
  357. urlStr := ``
  358. urlStr = "python/add"
  359. resp, _, err = postAddEdbData(param, urlStr)
  360. return
  361. }
  362. // EditPythonEdbData 编辑python指标
  363. func EditPythonEdbData(param string) (resp *models.BaseResponse, err error) {
  364. urlStr := ``
  365. urlStr = "python/edit"
  366. resp, _, err = postAddEdbData(param, urlStr)
  367. return
  368. }
  369. // SaveAdjustEdbInfo 保存数据调整指标
  370. func SaveAdjustEdbInfo(param string) (resp *models.BaseResponse, err error) {
  371. urlStr := ``
  372. urlStr = "calculate/adjust/save"
  373. resp, _, err = postAddEdbData(param, urlStr)
  374. return
  375. }
  376. // ResetCustomAnalysisData 重置自定义表格的数据
  377. func ResetCustomAnalysisData(reqStr string) (resp *AddPredictEdbDataResponse, err error) {
  378. _, resultByte, err := postAddEdbData(reqStr, "calculate/custom_analysis/reset")
  379. err = json.Unmarshal(resultByte, &resp)
  380. if err != nil {
  381. return
  382. }
  383. return
  384. }
  385. // CalculateComputeCorrelationResp 拟合残差计算相关性的值返回
  386. type CalculateComputeCorrelationResp struct {
  387. Ret int
  388. Msg string
  389. ErrMsg string
  390. ErrCode string
  391. Data string
  392. Success bool `description:"true 执行成功,false 执行失败"`
  393. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  394. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  395. }
  396. // CalculateComputeCorrelation 拟合残差计算相关性的值
  397. func CalculateComputeCorrelation(edbInfoCalculateBatchSaveReqStr string) (resp *CalculateComputeCorrelationResp, err error) {
  398. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "calculate/compute_correlation")
  399. err = json.Unmarshal(resultByte, &resp)
  400. if err != nil {
  401. return
  402. }
  403. return
  404. }
  405. // PredictCalculateComputeCorrelation 拟合残差计算相关性的值(预测指标)
  406. func PredictCalculateComputeCorrelation(edbInfoCalculateBatchSaveReqStr string) (resp *CalculateComputeCorrelationResp, err error) {
  407. _, resultByte, err := postAddEdbData(edbInfoCalculateBatchSaveReqStr, "predict_calculate/compute_correlation")
  408. err = json.Unmarshal(resultByte, &resp)
  409. if err != nil {
  410. return
  411. }
  412. return
  413. }
  414. // BaseCalculateResp 拟合残差计算相关性的值返回
  415. type BaseCalculateResp struct {
  416. Ret int
  417. Msg string
  418. ErrMsg string
  419. ErrCode string
  420. Data BaseCalculateDataResp
  421. Success bool `description:"true 执行成功,false 执行失败"`
  422. IsSendEmail bool `json:"-" description:"true 发送邮件,false 不发送邮件"`
  423. IsAddLog bool `json:"-" description:"true 新增操作日志,false 不新增操作日志" `
  424. }
  425. // BaseCalculateDataResp
  426. // @Description: 基础计算的返回结果
  427. type BaseCalculateDataResp struct {
  428. DataMap map[string]float64
  429. DateList []string
  430. }
  431. // BaseCalculate 基础计算
  432. func BaseCalculate(param string) (resp *BaseCalculateResp, err error) {
  433. urlStr := "calculate/base"
  434. _, resultByte, err := postAddEdbData(param, urlStr)
  435. err = json.Unmarshal(resultByte, &resp)
  436. if err != nil {
  437. return
  438. }
  439. return
  440. }
  441. // postRefreshEdbData 刷新指标数据
  442. func postRefreshEdbData(param map[string]interface{}, urlStr string) (resp *models.BaseResponse, err error) {
  443. postUrl := utils.EDB_LIB_URL + urlStr
  444. postData, err := json.Marshal(param)
  445. if err != nil {
  446. return
  447. }
  448. result, err := HttpPost(postUrl, string(postData), "application/json")
  449. if err != nil {
  450. return
  451. }
  452. utils.FileLog.Info("postRefreshEdbData:" + postUrl + ";" + string(postData) + ";result:" + string(result))
  453. err = json.Unmarshal(result, &resp)
  454. if err != nil {
  455. return
  456. }
  457. return resp, nil
  458. }
  459. // postAddEdbData 新增指标数据
  460. func postAddEdbData(paramStr string, urlStr string) (resp *models.BaseResponse, result []byte, err error) {
  461. postUrl := utils.EDB_LIB_URL + urlStr
  462. result, err = HttpPost(postUrl, paramStr, "application/json")
  463. if err != nil {
  464. return
  465. }
  466. err = json.Unmarshal(result, &resp)
  467. if err != nil {
  468. return
  469. }
  470. return
  471. }
  472. func HttpPost(url, postData string, params ...string) ([]byte, error) {
  473. body := ioutil.NopCloser(strings.NewReader(postData))
  474. client := &http.Client{}
  475. req, err := http.NewRequest("POST", url, body)
  476. if err != nil {
  477. return nil, err
  478. }
  479. contentType := "application/x-www-form-urlencoded;charset=utf-8"
  480. if len(params) > 0 && params[0] != "" {
  481. contentType = params[0]
  482. }
  483. req.Header.Set("Content-Type", contentType)
  484. req.Header.Set("authorization", utils.MD5(utils.APP_EDB_LIB_NAME_EN+utils.EDB_LIB_Md5_KEY))
  485. resp, err := client.Do(req)
  486. if err != nil {
  487. return nil, err
  488. }
  489. defer resp.Body.Close()
  490. b, err := ioutil.ReadAll(resp.Body)
  491. utils.FileLog.Debug("HttpPost:" + string(b))
  492. return b, err
  493. }