yongyi_data.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520
  1. package data_manage
  2. import (
  3. "eta/eta_api/models"
  4. "eta/eta_api/models/data_manage"
  5. "eta/eta_api/utils"
  6. "github.com/rdlucklib/rdluck_tools/paging"
  7. )
  8. // YongyiClassify
  9. // @Title 涌益咨询数据分类
  10. // @Description 涌益咨询数据分类接口
  11. // @Success 200 {object} data_manage.BaseFromYongyiClassify
  12. // @router /yongyi/classify [get]
  13. func (this *EdbInfoController) YongyiClassify() {
  14. br := new(models.BaseResponse).Init()
  15. defer func() {
  16. this.Data["json"] = br
  17. this.ServeJSON()
  18. }()
  19. sysUser := this.SysUser
  20. if sysUser == nil {
  21. br.Msg = "请登录"
  22. br.ErrMsg = "请登录,SysUser Is Empty"
  23. br.Ret = 408
  24. return
  25. }
  26. classifyAll, err := data_manage.GetAllBaseFromYongyiClassify()
  27. if err != nil && err.Error() != utils.ErrNoRow() {
  28. br.Msg = "获取失败"
  29. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  30. return
  31. }
  32. var ret data_manage.BaseFromYongyiClassifyResp
  33. ret.List = classifyAll
  34. br.Ret = 200
  35. br.Success = true
  36. br.Msg = "获取成功"
  37. br.Data = ret
  38. }
  39. // YongyiData
  40. // @Title 获取钢联数据
  41. // @Description 获取钢联数据接口
  42. // @Param PageSize query int true "每页数据条数"
  43. // @Param CurrentIndex query int true "当前页页码,从1开始"
  44. // @Param ClassifyId query string true "分类id"
  45. // @Param Frequency query string true "频度名称"
  46. // @Success 200 {object} data_manage.LzFrequency
  47. // @router /yongyi/index [get]
  48. func (this *EdbInfoController) YongyiData() {
  49. br := new(models.BaseResponse).Init()
  50. defer func() {
  51. this.Data["json"] = br
  52. this.ServeJSON()
  53. }()
  54. sysUser := this.SysUser
  55. if sysUser == nil {
  56. br.Msg = "请登录"
  57. br.ErrMsg = "请登录,SysUser Is Empty"
  58. br.Ret = 408
  59. return
  60. }
  61. pageSize, _ := this.GetInt("PageSize")
  62. currentIndex, _ := this.GetInt("CurrentIndex")
  63. var startSize int
  64. if pageSize <= 0 {
  65. pageSize = utils.PageSize20
  66. }
  67. if currentIndex <= 0 {
  68. currentIndex = 1
  69. }
  70. startSize = utils.StartIndex(currentIndex, pageSize)
  71. classifyId, _ := this.GetInt("ClassifyId")
  72. if classifyId < 0 {
  73. br.Msg = "请选择分类"
  74. br.ErrMsg = "请选择分类"
  75. return
  76. }
  77. //获取指标
  78. var condition string
  79. var pars []interface{}
  80. if classifyId >= 0 {
  81. condition += ` AND classify_id=? `
  82. pars = append(pars, classifyId)
  83. }
  84. yongyiList, err := data_manage.GetYongyiIndex(condition, pars)
  85. if err != nil {
  86. br.Msg = "获取数据失败"
  87. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  88. return
  89. }
  90. resultList := make([]*data_manage.BaseFromYongyiIndexList, 0)
  91. for _, v := range yongyiList {
  92. product := new(data_manage.BaseFromYongyiIndexList)
  93. product.YongyiIndexId = v.YongyiIndexId
  94. product.Unit = v.Unit
  95. product.IndexCode = v.IndexCode
  96. product.IndexName = v.IndexName
  97. product.Frequency = v.Frequency
  98. product.ModifyTime = v.ModifyTime
  99. total, err := data_manage.GetYongyiIndexDataCount(v.IndexCode)
  100. page := paging.GetPaging(currentIndex, pageSize, total)
  101. dataList, err := data_manage.GetYongyiIndexData(v.IndexCode, startSize, pageSize)
  102. if err != nil {
  103. br.Msg = "获取数据失败"
  104. br.ErrMsg = "获取指标数据失败,Err:" + err.Error()
  105. return
  106. }
  107. if dataList == nil {
  108. dataList = make([]*data_manage.BaseFromYongyiData, 0)
  109. }
  110. product.DataList = dataList
  111. product.Paging = page
  112. resultList = append(resultList, product)
  113. }
  114. br.Ret = 200
  115. br.Success = true
  116. br.Msg = "获取成功"
  117. br.Data = resultList
  118. }
  119. // YongyiSearchList
  120. // @Title Yongyi模糊搜索
  121. // @Description Yongyi模糊搜索
  122. // @Param Keyword query string ture "关键字搜索"
  123. // @Success 200 {object} models.BaseResponse
  124. // @router /yongyi/search_list [get]
  125. func (this *EdbInfoController) YongyiSearchList() {
  126. br := new(models.BaseResponse).Init()
  127. defer func() {
  128. this.Data["json"] = br
  129. this.ServeJSON()
  130. }()
  131. sysUser := this.SysUser
  132. if sysUser == nil {
  133. br.Msg = "请重新登录"
  134. return
  135. }
  136. //关键字
  137. /*keyword := this.GetString("Keyword")
  138. // todo es 模糊搜索
  139. list, err := data_manage.GetYongyiItemList(keyword)
  140. if err != nil {
  141. br.ErrMsg = "获取失败,Err:" + err.Error()
  142. br.Msg = "获取失败"
  143. return
  144. }
  145. br.Ret = 200
  146. br.Success = true
  147. br.Msg = "获取成功"
  148. br.Data = list*/
  149. }
  150. // YongyiSingleData
  151. // @Title 获取Yongyi数据
  152. // @Description 获取Yongyi单条数据接口
  153. // @Param IndexCode query string true "指标唯一编码"
  154. // @Success 200 {object} models.BaseResponse
  155. // @router /yongyi/single_data [get]
  156. func (this *EdbInfoController) YongyiSingleData() {
  157. /*br := new(models.BaseResponse).Init()
  158. defer func() {
  159. this.Data["json"] = br
  160. this.ServeJSON()
  161. }()
  162. sysUser := this.SysUser
  163. if sysUser == nil {
  164. br.Msg = "请登录"
  165. br.ErrMsg = "请登录,SysUser Is Empty"
  166. br.Ret = 408
  167. return
  168. }
  169. indexCode := this.GetString("IndexCode")
  170. indexInfo, err := data_manage.GetBaseFromYongyiIndexByIndexCode(indexCode)
  171. if err != nil {
  172. br.Msg = "获取指标信息失败"
  173. br.ErrMsg = "获取指标信息失败,Err:" + err.Error()
  174. return
  175. }
  176. dataList, err := data_manage.GetYongyiIndexDataByCode(indexCode)
  177. if err != nil {
  178. br.Msg = "获取数据失败"
  179. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  180. return
  181. }
  182. var ret data_manage.BaseFromYongyiSingleDataResp
  183. ret.ClassifyId = indexInfo.ClassifyId
  184. ret.BaseFromYongyiIndexId = indexInfo.BaseFromYongyiIndexId
  185. ret.IndexCode = indexInfo.IndexCode
  186. ret.IndexName = indexInfo.IndexName
  187. ret.Frequency = indexInfo.Frequency
  188. ret.Interface = indexInfo.Interface
  189. ret.CreateTime = indexInfo.CreateTime.Format(utils.FormatDateTime)
  190. ret.ModifyTime = indexInfo.ModifyTime.Format(utils.FormatDateTime)
  191. ret.Unit = indexInfo.Unit
  192. ret.Data = dataList
  193. br.Ret = 200
  194. br.Success = true
  195. br.Msg = "获取成功"
  196. br.Data = ret*/
  197. }
  198. // ExportYongyiList
  199. // @Title 导出Yongyi数据
  200. // @Description 导出Yongyi数据
  201. // @Param IndexName query string false "名称关键词"
  202. // @Param IndexCode query string false "指标唯一编码"
  203. // @Param ClassifyId query string true "分类"
  204. // @Param Frequency query string true "频度"
  205. // @Param UnitName query string false "单位"
  206. // @Param ModifyTime query string false "更新时间"
  207. // @Success 200 导出成功
  208. // @router /export/yongyiList [get]
  209. func (this *EdbInfoController) ExportYongyiList() {
  210. /*br := new(models.BaseResponse).Init()
  211. defer func() {
  212. this.Data["json"] = br
  213. this.ServeJSON()
  214. }()
  215. sysUser := this.SysUser
  216. if sysUser == nil {
  217. br.Msg = "请重新登录"
  218. return
  219. }
  220. //typeName := this.GetString("TypeName") //分类
  221. //frequency := this.GetString("Frequency")
  222. indexCode := this.GetString("IndexCode") //指标唯一编码
  223. classifyId, _ := this.GetInt("ClassifyId")
  224. secNameList := make([]*models.EdbdataExportList, 0)
  225. dir, _ := os.Executable()
  226. exPath := filepath.Dir(dir)
  227. downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  228. xlsxFile := xlsx.NewFile()
  229. if classifyId >= 0 && indexCode == "" {
  230. frequencies, err := data_manage.GetYongyiFrequency(classifyId)
  231. if err != nil {
  232. fmt.Println("GetYongyiFrequency err:", err.Error())
  233. utils.FileLog.Info("GetYongyiFrequency err:" + err.Error())
  234. return
  235. }
  236. for _, frequency := range frequencies {
  237. //获取指标
  238. var pars []interface{}
  239. pars = append(pars, classifyId)
  240. pars = append(pars, frequency)
  241. condition := " AND classify_id=? AND frequency=? "
  242. secNameList, err := data_manage.GetYongyiIndex(condition, pars)
  243. if err != nil {
  244. fmt.Println("获取数据失败,Err:" + err.Error())
  245. return
  246. }
  247. if len(secNameList) <= 0 {
  248. fmt.Println("secNameList长度为0")
  249. return
  250. }
  251. var sheetNew *xlsx.Sheet
  252. if *frequency == "" {
  253. newFrequency := "无频度"
  254. sheetNew, err = xlsxFile.AddSheet(newFrequency)
  255. } else {
  256. sheetNew, err = xlsxFile.AddSheet(*frequency)
  257. }
  258. if err != nil {
  259. fmt.Println("新增Sheet失败", err.Error())
  260. return
  261. }
  262. //sheetNew.SetColWidth()
  263. //获取指标数据
  264. windRow := sheetNew.AddRow()
  265. secNameRow := sheetNew.AddRow()
  266. indexCodeRow := sheetNew.AddRow()
  267. frequencyRow := sheetNew.AddRow()
  268. unitRow := sheetNew.AddRow()
  269. lastModifyDateRow := sheetNew.AddRow()
  270. //获取分类下指标最大数据量
  271. dataMax, err := data_manage.GetYongyiDataMaxCount(classifyId)
  272. if err != nil {
  273. fmt.Println("获取指标最大数据量失败", err.Error())
  274. return
  275. }
  276. fmt.Println("dataMax:", dataMax)
  277. setRowIndex := 6
  278. for k, sv := range secNameList {
  279. //获取数据
  280. dataList, err := data_manage.GetYongyiIndexDataByCode(sv.IndexCode)
  281. if err != nil {
  282. br.Msg = "获取数据失败"
  283. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  284. return
  285. }
  286. if len(dataList) > 0 {
  287. windRow.AddCell().SetValue("Yongyi")
  288. secNameRow.AddCell().SetValue("指标名称")
  289. indexCodeRow.AddCell().SetValue("指标ID")
  290. frequencyRow.AddCell().SetValue("频率")
  291. unitRow.AddCell().SetValue("单位")
  292. lastModifyDateRow.AddCell().SetValue("更新时间")
  293. secNameRow.AddCell().SetValue(sv.IndexName)
  294. indexCodeRow.AddCell().SetValue(sv.IndexCode)
  295. frequencyRow.AddCell().SetValue(sv.Frequency)
  296. unitRow.AddCell().SetValue(sv.Unit)
  297. lastModifyDateRow.AddCell().SetValue(sv.ModifyTime)
  298. windRow.AddCell()
  299. windRow.AddCell()
  300. secNameRow.AddCell()
  301. indexCodeRow.AddCell()
  302. frequencyRow.AddCell()
  303. unitRow.AddCell()
  304. lastModifyDateRow.AddCell()
  305. min := k * 3
  306. sheetNew.SetColWidth(min, min, 15)
  307. if len(dataList) <= 0 {
  308. for n := 0; n < dataMax; n++ {
  309. rowIndex := setRowIndex + n
  310. row := sheetNew.Row(rowIndex)
  311. row.AddCell()
  312. row.AddCell()
  313. row.AddCell()
  314. }
  315. } else {
  316. endRowIndex := 0
  317. for rk, dv := range dataList {
  318. rowIndex := setRowIndex + rk
  319. row := sheetNew.Row(rowIndex)
  320. displayDate, _ := time.Parse(utils.FormatDate, dv.DataTime)
  321. displayDateCell := row.AddCell()
  322. style := new(xlsx.Style)
  323. style.ApplyAlignment = true
  324. style.Alignment.WrapText = true
  325. displayDateCell.SetStyle(style)
  326. displayDateCell.SetDate(displayDate)
  327. row.AddCell().SetValue(dv.Value)
  328. row.AddCell()
  329. endRowIndex = rowIndex
  330. }
  331. if len(dataList) < dataMax {
  332. dataLen := dataMax - len(dataList)
  333. for n := 0; n < dataLen; n++ {
  334. rowIndex := (endRowIndex + 1) + n
  335. row := sheetNew.Row(rowIndex)
  336. row.AddCell()
  337. row.AddCell()
  338. row.AddCell()
  339. }
  340. }
  341. }
  342. }
  343. }
  344. }
  345. } else {
  346. frequencies, err := data_manage.GetYongyiFrequencyByCode(indexCode)
  347. if err != nil {
  348. fmt.Println("GetYongyiFrequencyByCode err:", err.Error())
  349. utils.FileLog.Info("GetYongyiFrequencyByCode err:" + err.Error())
  350. return
  351. }
  352. for _, frequency := range frequencies {
  353. //获取数据
  354. dataList, err := data_manage.GetYongyiIndexDataByCode(indexCode)
  355. if err != nil {
  356. br.Msg = "获取数据失败"
  357. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  358. return
  359. }
  360. if len(dataList) > 0 {
  361. name := this.GetString("IndexName")
  362. unit := this.GetString("UnitName")
  363. modifyTime := this.GetString("ModifyTime")
  364. var sheet *xlsx.Sheet
  365. if *frequency == "" {
  366. newFrequency := "无频度"
  367. sheet, err = xlsxFile.AddSheet(newFrequency)
  368. } else {
  369. sheet, err = xlsxFile.AddSheet(*frequency)
  370. }
  371. if err != nil {
  372. br.Msg = "新增Sheet失败"
  373. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  374. return
  375. }
  376. //获取指标数据
  377. windRow := sheet.AddRow()
  378. windRow.AddCell().SetValue("Yongyi")
  379. rowSecName := sheet.AddRow()
  380. celSecName := rowSecName.AddCell()
  381. celSecName.SetValue("指标名称")
  382. cellSenName := rowSecName.AddCell()
  383. cellSenName.SetValue(name)
  384. indexCodeRow := sheet.AddRow()
  385. indexCodeRow.AddCell().SetValue("指标ID")
  386. indexCodeRow.AddCell().SetValue(indexCode)
  387. rowFrequency := sheet.AddRow()
  388. celFrequency := rowFrequency.AddCell()
  389. celFrequency.SetValue("频率")
  390. cellFrequency := rowFrequency.AddCell()
  391. cellFrequency.SetValue(*frequency)
  392. rowUnit := sheet.AddRow()
  393. celUnit := rowUnit.AddCell()
  394. celUnit.SetValue("单位")
  395. cellUnit := rowUnit.AddCell()
  396. cellUnit.SetValue(unit)
  397. rowModifyDate := sheet.AddRow()
  398. rowModifyCell := rowModifyDate.AddCell()
  399. rowModifyCell.SetValue("更新时间")
  400. rowModifyCell = rowModifyDate.AddCell()
  401. rowModifyCell.SetValue(modifyTime)
  402. dataMax, err := data_manage.GetYongyiIndexDataCount(indexCode)
  403. if err != nil {
  404. br.Msg = "查询数量失败"
  405. br.ErrMsg = "GetYongyiIndexDataCount,Err:" + err.Error()
  406. return
  407. }
  408. if len(dataList) <= 0 {
  409. for n := 0; n < dataMax; n++ {
  410. rowIndex := 6 + n
  411. row := sheet.Row(rowIndex)
  412. row.AddCell()
  413. row.AddCell()
  414. row.AddCell()
  415. }
  416. } else {
  417. endRowIndex := 0
  418. for rk, dv := range dataList {
  419. rowIndex := 6 + rk
  420. row := sheet.Row(rowIndex)
  421. displayDate, _ := time.Parse(utils.FormatDate, dv.DataTime)
  422. displayDateCell := row.AddCell()
  423. style := new(xlsx.Style)
  424. style.ApplyAlignment = true
  425. style.Alignment.WrapText = true
  426. displayDateCell.SetStyle(style)
  427. displayDateCell.SetDate(displayDate)
  428. row.AddCell().SetValue(dv.Value)
  429. row.AddCell()
  430. endRowIndex = rowIndex
  431. }
  432. if len(dataList) < dataMax {
  433. dataLen := dataMax - len(dataList)
  434. for n := 0; n < dataLen; n++ {
  435. rowIndex := (endRowIndex + 1) + n
  436. row := sheet.Row(rowIndex)
  437. row.AddCell()
  438. row.AddCell()
  439. row.AddCell()
  440. }
  441. }
  442. }
  443. }
  444. }
  445. }
  446. err := xlsxFile.Save(downLoadnFilePath)
  447. if err != nil {
  448. //有指标无数据时先导出一遍空表
  449. sheet, err := xlsxFile.AddSheet("无数据")
  450. if err != nil {
  451. br.Msg = "新增Sheet失败"
  452. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  453. return
  454. }
  455. rowSecName := sheet.AddRow()
  456. celSecName := rowSecName.AddCell()
  457. celSecName.SetValue("")
  458. err = xlsxFile.Save(downLoadnFilePath)
  459. if err != nil {
  460. br.Msg = "保存文件失败"
  461. br.ErrMsg = "保存文件失败"
  462. return
  463. }
  464. }
  465. fileName := `Yongyi数据`
  466. if len(secNameList) > 0 {
  467. fileName = secNameList[0].ClassifyName
  468. }
  469. fileName += time.Now().Format("06.01.02") + `.xlsx` //文件名称
  470. this.Ctx.Output.Download(downLoadnFilePath, fileName)
  471. defer func() {
  472. os.Remove(downLoadnFilePath)
  473. }()
  474. br.Ret = 200
  475. br.Success = true
  476. br.Msg = "success"
  477. */
  478. }