base_edb_lib.go 14 KB

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