base_edb_lib.go 15 KB

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