pcsg_bloomberg.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. package index_data
  2. import (
  3. "encoding/json"
  4. "eta/eta_bridge/global"
  5. "eta/eta_bridge/models/pcsg"
  6. "fmt"
  7. "io/ioutil"
  8. "net/http"
  9. )
  10. // GetPCSGBloombergGeneralIndex 获取指标信息
  11. func GetPCSGBloombergGeneralIndex(taskKey, frequency string) (indexes []pcsg.BaseFromBloombergApiIndexAndData, err error) {
  12. apiData, e := CurlPCSGBloombergGeneralDataApi(taskKey)
  13. if e != nil {
  14. err = fmt.Errorf("CurlPCSGBloombergDailyApi err: %s", e.Error())
  15. return
  16. }
  17. if len(apiData) == 0 {
  18. return
  19. }
  20. conf, e := LoadPCSGBloombergTask(taskKey)
  21. if e != nil {
  22. err = fmt.Errorf("加载配置失败, Err: %v", e)
  23. return
  24. }
  25. if conf == nil {
  26. err = fmt.Errorf("加载配置异常, %s", taskKey)
  27. return
  28. }
  29. for _, v := range apiData {
  30. if taskKey == "IDpcsgDailyRun11" {
  31. tList := pcsg.FormatPythonBloombergDailyRun11Data2Base(v, frequency, taskKey)
  32. indexes = append(indexes, tList...)
  33. } else {
  34. t := pcsg.FormatPythonBloombergGeneralData2Base(v, conf)
  35. if t.IndexCode != "" {
  36. indexes = append(indexes, t)
  37. }
  38. }
  39. }
  40. return
  41. }
  42. // CurlPCSGBloombergGeneralDataApi 请求通用格式数据接口
  43. func CurlPCSGBloombergGeneralDataApi(taskKey string) (resultData []map[string]interface{}, err error) {
  44. if taskKey == "" {
  45. err = fmt.Errorf("任务Key为空")
  46. return
  47. }
  48. if global.CONFIG.PCSG.BloombergApiUrl == "" {
  49. err = fmt.Errorf("服务地址为空")
  50. return
  51. }
  52. url := fmt.Sprintf("%s/api/bloomberg/general_data?task_key=%s", global.CONFIG.PCSG.BloombergApiUrl, taskKey)
  53. resp, e := http.Get(url)
  54. if e != nil {
  55. err = fmt.Errorf("http post err: %s", e.Error())
  56. return
  57. }
  58. defer resp.Body.Close()
  59. b, e := ioutil.ReadAll(resp.Body)
  60. if e != nil {
  61. err = fmt.Errorf("resp body read err: %s", e.Error())
  62. return
  63. }
  64. if len(b) == 0 {
  65. err = fmt.Errorf("resp body is empty")
  66. return
  67. }
  68. //str := `{"Code":200,"Msg":"","Data":[{"DL_REQUEST_ID":"IDpcsgDailySnap0330","DL_REQUEST_NAME":"contractsLastHistory","DL_SNAPSHOT_START_TIME":"2024-07-09T08:30:03","DL_SNAPSHOT_TZ":"JST","IDENTIFIER":"Comdty B001","RC":0,"DATE":"2024-05-09","PX_LAST":1183.88},{"DL_REQUEST_ID":"IDpcsgDailySnap0330","DL_REQUEST_NAME":"contractsLastHistory","DL_SNAPSHOT_START_TIME":"2024-07-10T08:30:03","DL_SNAPSHOT_TZ":"JST","IDENTIFIER":"Comdty B001","RC":0,"DATE":"2024-05-10","PX_LAST":1182.79},{"DL_REQUEST_ID":"IDpcsgDailySnap0330","DL_REQUEST_NAME":"contractsLastHistory","DL_SNAPSHOT_START_TIME":"2024-07-09T08:30:03","DL_SNAPSHOT_TZ":"JST","IDENTIFIER":"Comdty B002","RC":0,"DATE":"2024-05-10","PX_LAST":1162.63}]}`
  69. //b := []byte(str)
  70. result := new(pcsg.PythonBloombergGeneralResult)
  71. if e = json.Unmarshal(b, &result); e != nil {
  72. err = fmt.Errorf("result unmarshal err: %s\nresult: %s", e.Error(), string(b))
  73. return
  74. }
  75. if result.Code != 200 {
  76. err = fmt.Errorf("result: %s", string(b))
  77. return
  78. }
  79. resultData = result.Data
  80. return
  81. }
  82. // LoadPCSGBloombergTask 加载配置
  83. func LoadPCSGBloombergTask(taskName string) (conf *pcsg.TaskConfPCSGBloomberg, err error) {
  84. filePath := "./static/pcsg_task.json"
  85. b, e := ioutil.ReadFile(filePath)
  86. if e != nil {
  87. err = fmt.Errorf("读取配置失败, err: %v", e)
  88. return
  89. }
  90. tasks := make([]*pcsg.TaskConfPCSGBloomberg, 0)
  91. if e = json.Unmarshal(b, &tasks); e != nil {
  92. err = fmt.Errorf("解析配置失败, err: %v", e)
  93. return
  94. }
  95. for _, v := range tasks {
  96. if v.TaskKey == taskName {
  97. conf = v
  98. break
  99. }
  100. }
  101. return
  102. }