manual_edb.go 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651
  1. package controllers
  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. "github.com/rdlucklib/rdluck_tools/paging"
  9. "github.com/shopspring/decimal"
  10. "strconv"
  11. "strings"
  12. "time"
  13. )
  14. // EdbDetail
  15. // @Title 指标列表
  16. // @Description 指标列表
  17. // @Param TradeCode query string true "指标编码"
  18. // @Success 200 {object} models.TargetDetailResp
  19. // @router /target/edb/detail [get]
  20. func (this *TargetController) EdbDetail() {
  21. br := new(models.BaseResponse).Init()
  22. defer func() {
  23. this.Data["json"] = br
  24. this.ServeJSON()
  25. }()
  26. sysUser := this.SysUser
  27. if sysUser == nil {
  28. br.Msg = "请重新登录"
  29. return
  30. }
  31. // 指标编码
  32. tradeCode := this.GetString("TradeCode")
  33. if tradeCode == `` {
  34. br.Msg = "请输入指标编码"
  35. br.IsSendEmail = false
  36. return
  37. }
  38. manualEdbInfo, err := models.GetTargetByTradeCode(tradeCode)
  39. if err != nil {
  40. br.Msg = "获取指标失败"
  41. br.ErrMsg = "获取指标失败,err:" + err.Error()
  42. return
  43. }
  44. // 如果不是超管账号,那么得校验下当前用户是否有该指标的权限
  45. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  46. //获取账户所拥有权限的分类id集合
  47. count, err := models.GetCountManualUserClassify(sysUser.AdminId, manualEdbInfo.ClassifyId)
  48. if err != nil {
  49. br.Msg = "获取分类数据失败"
  50. br.ErrMsg = "获取分类数据失败,err:" + err.Error()
  51. return
  52. }
  53. if count <= 0 {
  54. br.Msg = "无权访问"
  55. br.ErrMsg = "无权访问"
  56. br.IsSendEmail = false
  57. return
  58. }
  59. }
  60. classifyList := make([]*models.EdbdataClassify, 0)
  61. {
  62. classify, err := models.GetManualClassifyByClassifyId(manualEdbInfo.ClassifyId)
  63. if err != nil {
  64. br.Msg = "获取分类信息失败"
  65. br.ErrMsg = "获取分类信息失败,err:" + err.Error()
  66. return
  67. }
  68. parentClassify, err := models.GetManualClassifyByClassifyId(classify.ParentId)
  69. if err != nil {
  70. br.Msg = "获取分类信息失败"
  71. br.ErrMsg = "获取父级分类信息失败,err:" + err.Error()
  72. return
  73. }
  74. classifyList = []*models.EdbdataClassify{
  75. parentClassify, classify,
  76. }
  77. }
  78. // 明细数据
  79. {
  80. dataList, err := models.GetEdbDataListByCode(manualEdbInfo.TradeCode)
  81. if err != nil {
  82. br.Msg = "获取明细数据失败"
  83. br.ErrMsg = "获取明细数据失败,err:" + err.Error()
  84. return
  85. }
  86. manualEdbInfo.DataList = dataList
  87. }
  88. // 查找是否加入到指标库
  89. {
  90. edbInfo, err := data_manage.GetEdbInfoByEdbCode(utils.DATA_SOURCE_MANUAL, manualEdbInfo.TradeCode)
  91. if err != nil && err.Error() != utils.ErrNoRow() {
  92. br.Msg = "获取失败"
  93. br.ErrMsg = "获取失败,Err:" + err.Error()
  94. return
  95. }
  96. if edbInfo != nil {
  97. manualEdbInfo.EdbExist = 1
  98. }
  99. }
  100. resp := models.TargetDetailResp{
  101. Detail: manualEdbInfo,
  102. ClassifyList: classifyList,
  103. }
  104. br.Ret = 200
  105. br.Success = true
  106. br.Msg = "获取成功"
  107. //br.Data = resp
  108. br.Data = resp
  109. }
  110. // ClassifyEdbList
  111. // @Title 分类指标列表
  112. // @Description 指标列表
  113. // @Param ClassifyId query string true "分类id"
  114. // @Success 200 {object} models.TargetDetailResp
  115. // @router /target/classify/edb/list [get]
  116. func (this *TargetController) ClassifyEdbList() {
  117. br := new(models.BaseResponse).Init()
  118. defer func() {
  119. this.Data["json"] = br
  120. this.ServeJSON()
  121. }()
  122. sysUser := this.SysUser
  123. if sysUser == nil {
  124. br.Msg = "请登录"
  125. br.Ret = 408
  126. return
  127. }
  128. resp := new(models.EdbdataClassifyResp)
  129. classifyId, _ := this.GetInt("ClassifyId") //分类
  130. if classifyId <= 0 {
  131. br.Msg = "请传入分类"
  132. br.ErrMsg = "请传入分类"
  133. br.IsSendEmail = false
  134. }
  135. var condition string
  136. var pars []interface{}
  137. // 如果不是超管账号,那么得校验下当前用户是否有该指标的权限
  138. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  139. //获取账户所拥有权限的分类id集合
  140. count, err := models.GetCountManualUserClassify(sysUser.AdminId, classifyId)
  141. if err != nil {
  142. br.Msg = "获取分类数据失败"
  143. br.ErrMsg = "获取分类数据失败,err:" + err.Error()
  144. return
  145. }
  146. if count <= 0 {
  147. br.Msg = "无权访问"
  148. br.ErrMsg = "无权访问"
  149. br.IsSendEmail = false
  150. return
  151. }
  152. }
  153. list := make([]*models.EdbdataClassifyList, 0)
  154. condition += ` AND a.classify_id = ? `
  155. pars = append(pars, classifyId)
  156. tmpList, err := models.GetEdbInfoList(condition, pars, 0, 0)
  157. if err != nil {
  158. br.Msg = "获取失败"
  159. br.ErrMsg = "获取失败,Err:" + err.Error()
  160. return
  161. }
  162. for _, v := range tmpList {
  163. list = append(list, &models.EdbdataClassifyList{
  164. ClassifyId: 0,
  165. ClassifyName: v.SecName,
  166. ParentId: v.ClassifyId,
  167. Child: nil,
  168. TradeCode: v.TradeCode,
  169. UniqueCode: utils.MD5(v.TradeCode),
  170. })
  171. }
  172. resp.List = list
  173. br.Ret = 200
  174. br.Success = true
  175. br.Msg = "获取成功"
  176. br.Data = resp
  177. }
  178. // EdbSearch
  179. // @Title 指标搜索
  180. // @Description 指标搜索
  181. // @Param Keyword query string false "关键字搜索"
  182. // @Success 200 {object} models.TargetItemListResp
  183. // @router /target/edb/search [get]
  184. func (this *TargetController) EdbSearch() {
  185. br := new(models.BaseResponse).Init()
  186. defer func() {
  187. this.Data["json"] = br
  188. this.ServeJSON()
  189. }()
  190. sysUser := this.SysUser
  191. if sysUser == nil {
  192. br.Msg = "请重新登录"
  193. return
  194. }
  195. pageSize, _ := this.GetInt("PageSize")
  196. currentIndex, _ := this.GetInt("CurrentIndex")
  197. var startSize int
  198. if pageSize <= 0 {
  199. pageSize = utils.PageSize20
  200. }
  201. if currentIndex <= 0 {
  202. currentIndex = 1
  203. }
  204. startSize = utils.StartIndex(currentIndex, pageSize)
  205. //关键字
  206. keyword := this.GetString("Keyword")
  207. var condition string
  208. var pars []interface{}
  209. userId := sysUser.AdminId
  210. //超管账号可以查看分类下的所有频度数据
  211. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  212. classifyList, err := models.GetEdbdataClassify(int64(userId))
  213. if err != nil {
  214. br.Msg = "获取分类数据失败"
  215. br.Msg = "获取拥有的分类数据失败,Err:" + err.Error()
  216. return
  217. }
  218. num := len(classifyList)
  219. if num > 0 {
  220. classifyIdList := make([]int, 0)
  221. for _, v := range classifyList {
  222. classifyIdList = append(classifyIdList, v.ClassifyId)
  223. }
  224. condition += ` AND a.classify_id in (` + utils.GetOrmInReplace(num) + `) `
  225. pars = append(pars, classifyIdList)
  226. }
  227. }
  228. if keyword != "" {
  229. condition += ` AND (a.SEC_NAME like ? or a.TRADE_CODE like ? )`
  230. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  231. }
  232. total, err := models.GetCountEdbInfoList(condition, pars)
  233. if err != nil {
  234. br.Msg = "获取失败"
  235. br.ErrMsg = "获取失败,Err:" + err.Error()
  236. return
  237. }
  238. list, err := models.GetEdbInfoList(condition, pars, startSize, pageSize)
  239. if err != nil {
  240. br.Msg = "获取失败"
  241. br.ErrMsg = "获取失败,Err:" + err.Error()
  242. return
  243. }
  244. for _, v := range list {
  245. v.UniqueCode = utils.MD5(v.TradeCode)
  246. }
  247. resp := models.EdbListResp{
  248. List: list,
  249. Paging: paging.GetPaging(currentIndex, pageSize, total),
  250. }
  251. br.Ret = 200
  252. br.Success = true
  253. br.Msg = "获取成功"
  254. br.Data = resp
  255. }
  256. // EdbList
  257. // @Title 获取研究员指标
  258. // @Description 获取研究员指标
  259. // @Param Frequency query string false "频度;枚举值:日度、周度、月度、季度、半年度、年度"
  260. // @Param Keyword query string false "关键字搜索"
  261. // @Param TradeCode query string false "指标唯一编码"
  262. // @Param ClassifyId query int false "分类id"
  263. // @Param EdbShowType query string true "指标展示类型:0,1,2; 0:不管有没有数据,指标都展示出来, 1:只展示有数据的指标, 2:只展示没有数据的指标"
  264. // @Success 200 {object} models.TargetItemListResp
  265. // @router /target/edb/list [get]
  266. func (this *TargetController) EdbList() {
  267. br := new(models.BaseResponse).Init()
  268. defer func() {
  269. this.Data["json"] = br
  270. this.ServeJSON()
  271. }()
  272. sysUser := this.SysUser
  273. if sysUser == nil {
  274. br.Msg = "请重新登录"
  275. return
  276. }
  277. pageSize, _ := this.GetInt("PageSize")
  278. currentIndex, _ := this.GetInt("CurrentIndex")
  279. var startSize int
  280. if pageSize <= 0 {
  281. pageSize = utils.PageSize20
  282. }
  283. if currentIndex <= 0 {
  284. currentIndex = 1
  285. }
  286. startSize = utils.StartIndex(currentIndex, pageSize)
  287. //关键字
  288. keyword := this.GetString("Keyword")
  289. //关键字
  290. classifyId, _ := this.GetInt("ClassifyId", 0)
  291. var condition string
  292. var pars []interface{}
  293. userId := sysUser.AdminId
  294. //超管账号可以查看分类下的所有频度数据
  295. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  296. classifyList, err := models.GetEdbdataClassify(int64(userId))
  297. if err != nil {
  298. br.Msg = "获取分类数据失败"
  299. br.Msg = "获取拥有的分类数据失败,Err:" + err.Error()
  300. return
  301. }
  302. num := len(classifyList)
  303. if num > 0 {
  304. classifyIdList := make([]int, 0)
  305. for _, v := range classifyList {
  306. classifyIdList = append(classifyIdList, v.ClassifyId)
  307. }
  308. condition += ` AND a.classify_id in (` + utils.GetOrmInReplace(num) + `) `
  309. pars = append(pars, classifyIdList)
  310. }
  311. }
  312. // 关键词
  313. if keyword != "" {
  314. condition += ` AND (a.SEC_NAME like ? or a.TRADE_CODE like ? )`
  315. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  316. }
  317. // 所属分类
  318. if classifyId > 0 {
  319. condition += ` AND a.classify_id = ? `
  320. pars = append(pars, classifyId)
  321. }
  322. total, err := models.GetCountEdbInfoList(condition, pars)
  323. if err != nil {
  324. br.Msg = "获取失败"
  325. br.ErrMsg = "获取失败,Err:" + err.Error()
  326. return
  327. }
  328. list, err := models.GetEdbInfoList(condition, pars, startSize, pageSize)
  329. if err != nil {
  330. br.Msg = "获取失败"
  331. br.ErrMsg = "获取失败,Err:" + err.Error()
  332. return
  333. }
  334. resp := models.EdbListResp{
  335. List: list,
  336. Paging: paging.GetPaging(currentIndex, pageSize, total),
  337. }
  338. br.Ret = 200
  339. br.Success = true
  340. br.Msg = "获取成功"
  341. br.Data = resp
  342. }
  343. // EditExcelData
  344. // @Title 根据excel的样式去编辑指标
  345. // @Description 根据excel的样式去编辑指标
  346. // @Param request body models.ManualEdbExcelStyleEditReq true "type json string"
  347. // @Success 200
  348. // @router /target/edb/excel_style/edit [post]
  349. func (this *TargetController) EditExcelData() {
  350. br := new(models.BaseResponse).Init()
  351. var err error
  352. errs := make([]string, 0)
  353. defer func() {
  354. if len(errs) > 0 {
  355. utils.FileLog.Info("编辑EXCEL数据 新增或修改数据失败,Err:" + strings.Join(errs, "\n"))
  356. }
  357. this.Data["json"] = br
  358. this.ServeJSON()
  359. }()
  360. sysUser := this.SysUser
  361. if sysUser == nil {
  362. br.Msg = "请重新登录"
  363. return
  364. }
  365. var req data_manage.ManualEdbExcelStyleEditReq
  366. err = json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  367. if err != nil {
  368. br.Msg = "参数解析异常!"
  369. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  370. return
  371. }
  372. if req.TradeCode == `` {
  373. br.Msg = "指标编码异常!"
  374. br.ErrMsg = "指标编码异常!"
  375. return
  376. }
  377. if req.Unit == `` {
  378. br.Msg = "单位填写异常!"
  379. br.ErrMsg = "单位填写异常!"
  380. return
  381. }
  382. if req.Frequency == `` {
  383. br.Msg = "频度填写异常!"
  384. br.ErrMsg = "频度填写异常!"
  385. return
  386. }
  387. if req.ClassifyId <= 0 {
  388. br.Msg = "品种填写异常!"
  389. br.ErrMsg = "品种填写异常!"
  390. return
  391. }
  392. // 获取指标信息
  393. manualEdbInfo, err := models.GetEdbinfoByTradeCode(req.TradeCode)
  394. if err != nil {
  395. br.Msg = `找不到该指标`
  396. br.Msg = `找不到该指标,ERR:` + err.Error()
  397. return
  398. }
  399. // 如果不是超管账号,那么得校验下当前用户是否有该指标的权限
  400. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  401. //获取账户所拥有权限的分类id集合
  402. count, err := models.GetCountManualUserClassify(sysUser.AdminId, manualEdbInfo.ClassifyId)
  403. if err != nil {
  404. br.Msg = "获取分类数据失败"
  405. br.ErrMsg = "获取分类数据失败,err:" + err.Error()
  406. return
  407. }
  408. if count <= 0 {
  409. br.Msg = "无权访问"
  410. br.ErrMsg = "无权访问"
  411. br.IsSendEmail = false
  412. return
  413. }
  414. }
  415. dateValueMap := make(map[string]string)
  416. //取到所有数据
  417. for i := range req.Data {
  418. // 过滤第一行
  419. if i == 0 {
  420. continue
  421. }
  422. if req.Data[i] == nil {
  423. continue
  424. }
  425. tmpData := req.Data[i]
  426. // 少于两列,说明数据是异常的,得过滤
  427. if len(tmpData) < 2 {
  428. continue
  429. }
  430. var tmpDate string
  431. //先拿下日期列表
  432. {
  433. dateMap := tmpData[0].(map[string]interface{})
  434. _, ok := dateMap["m"]
  435. if !ok {
  436. continue
  437. }
  438. tmpDate = dateMap["m"].(string)
  439. }
  440. // 数据处理
  441. {
  442. if tmpData[1] == nil {
  443. continue
  444. }
  445. valueMap := tmpData[1].(map[string]interface{})
  446. value, _ := valueMap["m"]
  447. if value == nil {
  448. continue
  449. }
  450. dateValueMap[tmpDate] = valueMap["m"].(string)
  451. // 09-27 千位分隔符时用 "m" 取字符串存数据库会把逗号当小数点,现在换用 "v" 直接取数字再转为字符串,看看会不会有问题
  452. if ct, ok := valueMap["ct"].(map[string]interface{}); ok {
  453. fa, _ := ct["fa"]
  454. if fa == "#,##0.000" {
  455. value = valueMap["v"]
  456. floatValue := valueMap["v"].(float64)
  457. dateValueMap[tmpDate] = strconv.FormatFloat(floatValue, 'f', -1, 64)
  458. }
  459. }
  460. }
  461. }
  462. //操作指标,新增指标及数据等
  463. {
  464. secName := strings.TrimSpace(req.Name)
  465. frequency := strings.TrimSpace(req.Frequency)
  466. unit := strings.TrimSpace(req.Unit)
  467. // 指标基础信息变更
  468. {
  469. updateCols := make([]string, 0)
  470. if manualEdbInfo.SecName != secName {
  471. updateCols = append(updateCols, "SecName")
  472. manualEdbInfo.SecName = secName
  473. }
  474. if manualEdbInfo.ClassifyId != req.ClassifyId {
  475. updateCols = append(updateCols, "ClassifyId")
  476. manualEdbInfo.ClassifyId = req.ClassifyId
  477. }
  478. if manualEdbInfo.Frequency != frequency {
  479. updateCols = append(updateCols, "Frequency")
  480. manualEdbInfo.Frequency = frequency
  481. }
  482. if manualEdbInfo.Unit != unit {
  483. updateCols = append(updateCols, "Unit")
  484. manualEdbInfo.Unit = unit
  485. }
  486. if len(updateCols) > 0 {
  487. err = manualEdbInfo.Update(updateCols)
  488. if err != nil {
  489. br.Msg = `指标保存失败`
  490. br.Msg = `指标保存失败,ERR:` + err.Error()
  491. return
  492. }
  493. }
  494. }
  495. // 当前已经存在的指标明细数据
  496. targetDataList, tmpErr := models.GetTargetsDataList(manualEdbInfo.TradeCode)
  497. if tmpErr != nil {
  498. err = tmpErr
  499. }
  500. existDataMap := make(map[string]string)
  501. deleteDataMap := make(map[string]string)
  502. for _, tmpData := range targetDataList {
  503. existDataMap[tmpData.Dt] = tmpData.Close
  504. deleteDataMap[tmpData.Dt] = tmpData.Dt
  505. }
  506. addDataList := make([]*models.Edbdata, 0)
  507. for createDate, closeVal := range dateValueMap {
  508. if createDate == "" || closeVal == "" {
  509. continue
  510. }
  511. //判断数据是否已经存在
  512. tmpVal, ok3 := existDataMap[createDate]
  513. // 不存在,那么后面进行插入
  514. if !ok3 {
  515. addDataList = append(addDataList, &models.Edbdata{
  516. TradeCode: manualEdbInfo.TradeCode,
  517. Dt: createDate,
  518. Close: closeVal,
  519. ModifyTime: time.Now(),
  520. })
  521. continue
  522. }
  523. delete(deleteDataMap, createDate)
  524. // 库里面的数据
  525. tmpValDecimal, tmpErr := decimal.NewFromString(tmpVal)
  526. if tmpErr != nil {
  527. fmt.Println("tmpVal Parse err:", tmpErr.Error())
  528. err = tmpErr
  529. continue
  530. }
  531. // 用户填写的数据
  532. closeValDecimal, tmpErr := decimal.NewFromString(closeVal)
  533. if tmpErr != nil {
  534. fmt.Println("closeVal Parse err:", tmpErr.Error())
  535. err = tmpErr
  536. continue
  537. }
  538. if !tmpValDecimal.Equal(closeValDecimal) {
  539. fmt.Println("更新数值")
  540. err = models.ModifyTargetsDataByImport(manualEdbInfo.TradeCode, createDate, closeVal)
  541. if err != nil {
  542. fmt.Println("ModifyTargetsDataByImport err:", err.Error())
  543. errs = append(errs, err.Error())
  544. //go utils.SendEmail(utils.APPNAME+"失败提醒", "导入数据 修改数据失败:Err:"+err.Error(), utils.EmailSendToUsers)
  545. }
  546. }
  547. }
  548. // 新增指标
  549. if len(addDataList) > 0 {
  550. err = models.OnlyMultiAddEdbdata(addDataList)
  551. if err != nil {
  552. fmt.Println("MultiAddEdbdata err:", err.Error())
  553. errs = append(errs, err.Error())
  554. }
  555. }
  556. // 删除不需要的日期数据
  557. num := len(deleteDataMap)
  558. if num > 0 {
  559. deleteDateList := make([]string, 0)
  560. for date := range deleteDataMap {
  561. deleteDateList = append(deleteDateList, date)
  562. }
  563. err = models.DelEdbdataByCodeAndDateList(manualEdbInfo.TradeCode, deleteDateList)
  564. if err != nil {
  565. fmt.Println("DelEdbdataByCodeAndDateList err:", err.Error())
  566. errs = append(errs, err.Error())
  567. }
  568. }
  569. }
  570. br.Ret = 200
  571. br.Success = true
  572. br.Msg = "保存成功"
  573. }