123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416 |
- package data_source
- import (
- "eta/eta_api/controllers"
- "eta/eta_api/models"
- "eta/eta_api/models/data_source"
- "eta/eta_api/utils"
- "fmt"
- "github.com/tealeg/xlsx"
- "os"
- "path/filepath"
- "strconv"
- "time"
- )
- // 广州期货交易所
- type DataSourceController struct {
- controllers.BaseAuthController
- }
- // ComTradeCountryList
- // @Title 获取广州期货交易所分类
- // @Description 获取广州期货交易所分类
- // @Success 200 {object} []data_manage.ComTradeCountryItem
- // @router /gfex/classify/list [get]
- func (this *DataSourceController) GfexClassifyList() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- gzqhObj := new(data_source.BaseFromTradeGuangzhouIndex)
- classifyList, err := gzqhObj.GetBaseFromTradeGuangzhouClassifyAll()
- if err != nil {
- br.Msg = "获取分类失败"
- br.ErrMsg = "获取分类失败,Err:" + err.Error()
- return
- }
- classifyMap := make(map[int][]*data_source.BaseFromTradeGuangzhouClassifyView)
- for _, v := range classifyList {
- if v.ParentId == 0 {
- continue
- }
- if items, ok := classifyMap[v.ParentId]; !ok {
- list := make([]*data_source.BaseFromTradeGuangzhouClassifyView, 0)
- list = append(list, v)
- classifyMap[v.ParentId] = list
- } else {
- items = append(items, v)
- classifyMap[v.ParentId] = items
- }
- }
- classifyItems := make([]*data_source.BaseFromTradeGuangzhouClassifyView, 0)
- for _, v := range classifyList {
- if v.ParentId == 0 {
- v.Children = classifyMap[v.BaseFromTradeGuangzhouClassifyId]
- classifyItems = append(classifyItems, v)
- }
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = classifyItems
- }
- // ComTradeCountryList
- // @Title 获取广州期货交易所数据最大日期
- // @Description 获取广州期货交易所数据最大日期
- // @Success 200 {object} []data_source.ComTradeCountryItem
- // @router /gfex/max/date [get]
- func (this *DataSourceController) GfexMaxDate() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- gzqhObj := new(data_source.BaseFromTradeGuangzhouIndex)
- maxDate, err := gzqhObj.GetBaseFromTradeGuangzhouMaxDate()
- if err != nil {
- br.ErrMsg = "获取最新日期失败,Err:" + err.Error()
- br.Msg = "获取最新日期失败"
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = maxDate
- }
- // ComTradeCountryList
- // @Title 获取广州期货交易所-分类下合约
- // @Description 获取广州期货交易所-分类下合约
- // @Param BaseFromTradeGuangzhouClassifyId query int true "分类id"
- // @Param TradeDate query string true "日期"
- // @Success 200 {object} []data_source.BaseFromTradeGuangzhouContract
- // @router /gfex/contract [get]
- func (this *DataSourceController) GfexContract() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- baseFromTradeGuangzhouClassifyId, _ := this.GetInt("BaseFromTradeGuangzhouClassifyId", 0)
- if baseFromTradeGuangzhouClassifyId <= 0 {
- br.Msg = "参数错误"
- br.Msg = "分类id错误"
- return
- }
- tradeDate := this.GetString("TradeDate")
- if tradeDate == "" {
- br.Msg = "参数错误"
- br.Msg = "交易日期不能为空"
- return
- }
- gzqhObj := new(data_source.BaseFromTradeGuangzhouIndex)
- list, err := gzqhObj.GetBaseFromTradeGuangzhouContract(baseFromTradeGuangzhouClassifyId, tradeDate)
- if err != nil {
- br.ErrMsg = "获取数据失败,Err:" + err.Error()
- br.Msg = "获取数据失败"
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = list
- }
- // ComTradeCountryList
- // @Title 获取广州期货交易所-分类下指标信息
- // @Description 获取广州期货交易所-分类下指标信息
- // @Param BaseFromTradeGuangzhouClassifyId query int true "分类id"
- // @Param BaseFromTradeGuangzhouContractId query int true "合约id"
- // @Param TradeDate query string true "日期"
- // @Success 200 {object} []data_source.BaseFromTradeGuangzhouIndexView
- // @router /gfex/index_data [get]
- func (this *DataSourceController) GfexIndexData() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- baseFromTradeGuangzhouClassifyId, _ := this.GetInt("BaseFromTradeGuangzhouClassifyId", 0)
- if baseFromTradeGuangzhouClassifyId <= 0 {
- br.Msg = "参数错误"
- br.ErrMsg = "分类id错误"
- return
- }
- tradeDate := this.GetString("TradeDate")
- if tradeDate == "" {
- br.Msg = "参数错误"
- br.ErrMsg = "交易日期不能为空"
- return
- }
- baseFromTradeGuangzhouContractId, err := this.GetInt("BaseFromTradeGuangzhouContractId", 0)
- fmt.Println(err)
- fmt.Println(baseFromTradeGuangzhouContractId)
- var condition string
- var pars []interface{}
- if baseFromTradeGuangzhouContractId > 0 {
- condition += ` b.data_time=? `
- pars = append(pars, tradeDate)
- condition += ` AND a.base_from_trade_guangzhou_classify_id=? `
- pars = append(pars, baseFromTradeGuangzhouClassifyId)
- } else {
- if baseFromTradeGuangzhouClassifyId == 11 || baseFromTradeGuangzhouClassifyId == 12 { //月度数据处理
- td, err := time.Parse(utils.FormatDate, tradeDate)
- if err != nil {
- br.Msg = "日期格式错误"
- br.ErrMsg = "日期格式错误,Err:" + err.Error()
- return
- }
- _, monthEndDay := utils.GetMonthStartAndEnd(strconv.Itoa(td.Year()), strconv.Itoa(int(td.Month())))
- condition += ` a.data_time=? `
- pars = append(pars, monthEndDay)
- } else {
- condition += ` a.data_time=? `
- pars = append(pars, tradeDate)
- }
- condition += ` AND b.base_from_trade_guangzhou_classify_id=? `
- pars = append(pars, baseFromTradeGuangzhouClassifyId)
- }
- //if baseFromTradeGuangzhouContractId > 0 {
- // condition += ` AND c.base_from_trade_guangzhou_contract_id=? `
- // pars = append(pars, baseFromTradeGuangzhouContractId)
- //}
- gzqhObj := new(data_source.BaseFromTradeGuangzhouIndex)
- list, err := gzqhObj.GetBaseFromTradeGuangzhouIndex(condition, pars, baseFromTradeGuangzhouContractId)
- if err != nil {
- br.ErrMsg = "获取数据失败,Err:" + err.Error()
- br.Msg = "获取数据失败"
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = list
- }
- // @Title 获取广州期货交易所-一次性交割卖方仓单明细
- // @Description 获取广州期货交易所-一次性交割卖方仓单明细
- // @Param BaseFromTradeGuangzhouIndexId query int true "指标id"
- // @Param TradeDate query string true "日期"
- // @Success 200 {object} []data_source.BaseFromTradeGuangzhouIndexView
- // @router /gfex/index/detail [get]
- func (this *DataSourceController) GfexIndexDetail() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请登录"
- br.ErrMsg = "请登录,SysUser Is Empty"
- br.Ret = 408
- return
- }
- baseFromTradeGuangzhouIndexId, _ := this.GetInt("BaseFromTradeGuangzhouIndexId", 0)
- if baseFromTradeGuangzhouIndexId < 0 {
- br.Msg = "参数错误"
- return
- }
- tradeDate := this.GetString("TradeDate")
- if tradeDate == "" {
- br.Msg = "参数错误"
- br.ErrMsg = "交易日期不能为空"
- return
- }
- var condition string
- var pars []interface{}
- condition += ` a.base_from_trade_guangzhou_classify_id = ? `
- pars = append(pars, baseFromTradeGuangzhouIndexId)
- td, err := time.Parse(utils.FormatDate, tradeDate)
- if err != nil {
- br.Msg = "日期格式错误"
- br.ErrMsg = "日期格式错误,Err:" + err.Error()
- return
- }
- _, monthEndDay := utils.GetMonthStartAndEnd(strconv.Itoa(td.Year()), strconv.Itoa(int(td.Month())))
- condition += ` AND a.end_date = ? `
- pars = append(pars, monthEndDay)
- gzqhObj := new(data_source.BaseFromTradeGuangzhouIndex)
- list, err := gzqhObj.GetBaseFromTradeGuangzhouIndexDetail(condition, pars)
- if err != nil {
- br.ErrMsg = "获取数据失败,Err:" + err.Error()
- br.Msg = "获取数据失败"
- return
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = list
- }
- // @Title 导出广州期货交易所-一次性交割卖方仓单明细
- // @Description 导出广州期货交易所-一次性交割卖方仓单明细
- // @Param BaseFromTradeGuangzhouIndexId query int true "指标id"
- // @Param TradeDate query string true "日期"
- // @Success 200 导出成功
- // @router /gfex/index/detail/export [get]
- func (this *DataSourceController) ExportGfexIndexDetail() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- sysUser := this.SysUser
- if sysUser == nil {
- br.Msg = "请重新登录"
- return
- }
- baseFromTradeGuangzhouIndexId, _ := this.GetInt("BaseFromTradeGuangzhouIndexId", 0)
- if baseFromTradeGuangzhouIndexId < 0 {
- br.Msg = "参数错误"
- return
- }
- tradeDate := this.GetString("TradeDate")
- if tradeDate == "" {
- br.Msg = "参数错误"
- br.ErrMsg = "交易日期不能为空"
- return
- }
- var condition string
- var pars []interface{}
- condition += ` a.base_from_trade_guangzhou_classify_id = ? `
- pars = append(pars, baseFromTradeGuangzhouIndexId)
- td, err := time.Parse(utils.FormatDate, tradeDate)
- if err != nil {
- br.Msg = "日期格式错误"
- br.ErrMsg = "日期格式错误,Err:" + err.Error()
- return
- }
- _, monthEndDay := utils.GetMonthStartAndEnd(strconv.Itoa(td.Year()), strconv.Itoa(int(td.Month())))
- condition += ` AND a.end_date = ? `
- pars = append(pars, monthEndDay)
- gzqhObj := new(data_source.BaseFromTradeGuangzhouIndex)
- list, err := gzqhObj.GetBaseFromTradeGuangzhouIndexDetail(condition, pars)
- if err != nil {
- br.ErrMsg = "获取数据失败,Err:" + err.Error()
- br.Msg = "获取数据失败"
- return
- }
- dir, _ := os.Executable()
- exPath := filepath.Dir(dir)
- downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
- xlsxFile := xlsx.NewFile()
- sheetNew, err := xlsxFile.AddSheet("详情")
- if err != nil {
- br.ErrMsg = "导出失败,Err:" + err.Error()
- br.Msg = "导出失败"
- return
- }
- titleRow := sheetNew.AddRow()
- titleRow.AddCell().SetValue("指标ID")
- titleRow.AddCell().SetValue("指标名称")
- titleRow.AddCell().SetValue("数值")
- titleRow.AddCell().SetValue("单位")
- titleRow.AddCell().SetValue("频度")
- titleRow.AddCell().SetValue("起始日期")
- titleRow.AddCell().SetValue("最新日期")
- var indexCode string
- for _, sv := range list {
- dataRow := sheetNew.AddRow()
- dataRow.AddCell().SetValue(sv.IndexCode)
- dataRow.AddCell().SetValue(sv.IndexName)
- dataRow.AddCell().SetValue(sv.Value)
- dataRow.AddCell().SetValue(sv.Unit)
- dataRow.AddCell().SetValue(sv.Frequency)
- dataRow.AddCell().SetValue(sv.StartDate)
- dataRow.AddCell().SetValue(sv.EndDate)
- indexCode = sv.IndexCode
- }
- err = xlsxFile.Save(downLoadnFilePath)
- if err != nil {
- //有指标无数据时先导出一遍空表
- sheet, err := xlsxFile.AddSheet("无数据")
- if err != nil {
- br.Msg = "新增Sheet失败"
- br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
- return
- }
- rowSecName := sheet.AddRow()
- celSecName := rowSecName.AddCell()
- celSecName.SetValue("")
- err = xlsxFile.Save(downLoadnFilePath)
- if err != nil {
- br.Msg = "保存文件失败"
- br.ErrMsg = "保存文件失败"
- return
- }
- }
- fileName := `一次性交割卖方仓单详情`
- fileName = indexCode[:6] + fileName + `.xlsx` //文件名称
- this.Ctx.Output.Download(downLoadnFilePath, fileName)
- defer func() {
- os.Remove(downLoadnFilePath)
- }()
- br.Ret = 200
- br.Success = true
- br.Msg = "success"
- }
|