base_edb_lib.go 17 KB

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