base_from_kpler.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604
  1. package models
  2. import (
  3. sql2 "database/sql"
  4. "eta/eta_index_lib/global"
  5. "eta/eta_index_lib/utils"
  6. "fmt"
  7. "gorm.io/gorm"
  8. "strconv"
  9. "strings"
  10. "time"
  11. )
  12. // BaseFromKpler Kpler数据
  13. type BaseFromKpler struct{}
  14. type BaseFromKplerData struct {
  15. BaseFromKplerDataId int `gorm:"column:base_from_kpler_data_id;primaryKey"`
  16. //BaseFromKplerDataId int `orm:"column(base_from_kpler_data_id);pk"`
  17. BaseFromKplerIndexId int
  18. IndexCode string
  19. DataTime string
  20. Value string
  21. CreateTime time.Time
  22. ModifyTime time.Time
  23. DataTimestamp int64
  24. }
  25. func (e *BaseFromKplerData) AfterFind(db *gorm.DB) (err error) {
  26. e.DataTime = utils.GormDateStrToDateStr(e.DataTime)
  27. return
  28. }
  29. func GetBaseFromKplerDataByCondition(condition string, pars []interface{}) (list []*BaseFromKplerData, err error) {
  30. //o := orm.NewOrm()
  31. sql := `SELECT * FROM base_from_kpler_data WHERE 1=1 `
  32. if condition != "" {
  33. sql += condition
  34. }
  35. //_, err = o.Raw(sql, pars).QueryRows(&list)
  36. err = global.DEFAULT_DB.Raw(sql, pars...).Find(&list).Error
  37. return
  38. }
  39. // Add 添加
  40. func (obj BaseFromKpler) Add(edbCode string) (err error) {
  41. //o := orm.NewOrm()
  42. var condition string
  43. var pars []interface{}
  44. if edbCode != "" {
  45. condition += " AND index_code=? "
  46. pars = append(pars, edbCode)
  47. }
  48. KplerBaseDataAll, err := GetBaseFromKplerDataByCondition(condition, pars)
  49. if err != nil && !utils.IsErrNoRow(err) {
  50. return
  51. }
  52. var isAdd bool
  53. addSql := ` INSERT INTO edb_data_kpler(edb_info_id,edb_code,data_time,value,create_time,modify_time,data_timestamp) values `
  54. existMap := make(map[string]string)
  55. for _, sv := range KplerBaseDataAll {
  56. eDate := sv.DataTime
  57. dataTime, err := time.Parse(utils.FormatDate, eDate)
  58. if err != nil {
  59. return err
  60. }
  61. timestamp := dataTime.UnixNano() / 1e6
  62. timeStr := fmt.Sprintf("%d", timestamp)
  63. if _, ok := existMap[eDate]; !ok {
  64. addSql += GetAddSql("0", edbCode, eDate, timeStr, sv.Value)
  65. isAdd = true
  66. }
  67. existMap[eDate] = sv.Value
  68. }
  69. if isAdd {
  70. addSql = strings.TrimRight(addSql, ",")
  71. utils.FileLog.Info("addSql:" + addSql)
  72. //_,err=o.Raw(addSql).Exec()
  73. err = global.DEFAULT_DB.Exec(addSql).Error
  74. if err != nil {
  75. return err
  76. }
  77. }
  78. return
  79. }
  80. // Refresh 刷新Kpler指标数据
  81. func (obj BaseFromKpler) Refresh(edbInfoId int, edbCode, startDate string) (err error) {
  82. source := obj.GetSource()
  83. //o := orm.NewOrm()
  84. if err != nil {
  85. return
  86. }
  87. edbInfoIdStr := strconv.Itoa(edbInfoId)
  88. //计算数据
  89. var condition string
  90. var pars []interface{}
  91. if edbCode != "" {
  92. condition += " AND index_code=? "
  93. pars = append(pars, edbCode)
  94. }
  95. if startDate != "" {
  96. condition += " AND data_time>=? "
  97. pars = append(pars, startDate)
  98. }
  99. KplerDataList, err := GetBaseFromKplerDataByCondition(condition, pars)
  100. if err != nil {
  101. return
  102. }
  103. // 真实数据的最大日期 , 插入规则配置的日期
  104. var realDataMaxDate, edbDataInsertConfigDate time.Time
  105. var edbDataInsertConfig *EdbDataInsertConfig
  106. var isFindConfigDateRealData bool //是否找到配置日期的实际数据的值
  107. {
  108. edbDataInsertConfig, err = GetEdbDataInsertConfigByEdbId(edbInfoId)
  109. if err != nil && !utils.IsErrNoRow(err) {
  110. return
  111. }
  112. if edbDataInsertConfig != nil {
  113. edbDataInsertConfigDate = edbDataInsertConfig.Date
  114. }
  115. }
  116. var existCondition string
  117. var existPars []interface{}
  118. existCondition += " AND edb_info_id=? "
  119. existPars = append(existPars, edbInfoId)
  120. if startDate != "" {
  121. existCondition += " AND data_time>=? "
  122. existPars = append(existPars, startDate)
  123. }
  124. existList, err := GetEdbDataByCondition(source, 0, existCondition, existPars)
  125. if err != nil {
  126. return err
  127. }
  128. existMap := make(map[string]*EdbInfoSearchData)
  129. for _, v := range existList {
  130. existMap[v.DataTime] = v
  131. }
  132. addSql := ` INSERT INTO edb_data_kpler(edb_info_id,edb_code,data_time,value,create_time,modify_time,data_timestamp) values `
  133. var isAdd bool
  134. for _, v := range KplerDataList {
  135. item := v
  136. eDate := item.DataTime
  137. dataTime, err := time.ParseInLocation(utils.FormatDate, eDate, time.Local)
  138. if err != nil {
  139. return err
  140. }
  141. if findItem, ok := existMap[v.DataTime]; !ok {
  142. sValue := item.Value
  143. timestamp := dataTime.UnixNano() / 1e6
  144. timeStr := fmt.Sprintf("%d", timestamp)
  145. addSql += GetAddSql(edbInfoIdStr, edbCode, eDate, timeStr, sValue)
  146. isAdd = true
  147. } else {
  148. if findItem != nil && utils.SubFloatToString(findItem.Value, 30) != item.Value {
  149. err = ModifyEdbDataById(source, 0, findItem.EdbDataId, item.Value)
  150. if err != nil {
  151. return err
  152. }
  153. }
  154. }
  155. // 下面代码主要目的是处理掉手动插入的数据判断
  156. {
  157. if realDataMaxDate.IsZero() || dataTime.After(realDataMaxDate) {
  158. realDataMaxDate = dataTime
  159. }
  160. if edbDataInsertConfigDate.IsZero() || dataTime.Equal(edbDataInsertConfigDate) {
  161. isFindConfigDateRealData = true
  162. }
  163. }
  164. }
  165. // 处理手工数据补充的配置
  166. HandleConfigInsertEdbData(realDataMaxDate, edbDataInsertConfig, edbInfoId, source, 0, existMap, isFindConfigDateRealData)
  167. if isAdd {
  168. addSql = strings.TrimRight(addSql, ",")
  169. //_,err = o.Raw(assSql).Exec()
  170. err = global.DEFAULT_DB.Exec(addSql).Error
  171. if err != nil {
  172. fmt.Println("RefreshEdbDataFromKpler add Err", err.Error())
  173. return
  174. }
  175. }
  176. return
  177. }
  178. // GetSource 获取来源编码id
  179. func (obj BaseFromKpler) GetSource() int {
  180. return utils.DATA_SOURCE_KPLER
  181. }
  182. // GetSourceName 获取来源名称
  183. func (obj BaseFromKpler) GetSourceName() string {
  184. return utils.DATA_SOURCE_NAME_KPLER
  185. }
  186. type BaseFromKplerIndex struct {
  187. BaseFromKplerIndexId int `gorm:"column:base_from_kpler_index_id;primaryKey"`
  188. //BaseFromKplerIndexId int `orm:"column(base_from_kpler_index_id);pk"`
  189. ClassifyId int
  190. IndexCode string
  191. IndexName string
  192. Frequency string
  193. Unit string
  194. Sort int
  195. StartDate string `description:"开始日期"`
  196. EndDate string `description:"结束日期"`
  197. EndValue float64
  198. CreateTime time.Time
  199. ModifyTime time.Time
  200. BaseFileName string `description:"文件目录"`
  201. TerminalCode string `description:"所属终端编码"`
  202. ApiQueryUrl string `description:"API查询URL"`
  203. ProductNames string `description:"产品名称"`
  204. FromZoneId int `description:"区域ID"`
  205. FromZoneName string `description:"区域名称"`
  206. ToZoneId int `description:"区域ID"`
  207. ToZoneName string `description:"区域名称"`
  208. FlowDirection string `description:"流向"`
  209. Granularity string `description:"粒度"`
  210. Split string `description:"拆分类型"`
  211. }
  212. func (e *BaseFromKplerIndex) AfterFind(db *gorm.DB) (err error) {
  213. e.StartDate = utils.GormDateStrToDateStr(e.StartDate)
  214. e.EndDate = utils.GormDateStrToDateStr(e.EndDate)
  215. return
  216. }
  217. type BaseFromKplerIndexList struct {
  218. BaseFromKplerIndexId int `gorm:"column:base_from_kpler_index_id;primaryKey"`
  219. //BaseFromKplerIndexId int `orm:"column(base_from_kpler_index_id);pk"`
  220. IndexCode string
  221. IndexName string
  222. Frequency string
  223. Unit string
  224. Sort int
  225. ClassifyId int
  226. StartDate string
  227. EndDate string
  228. TerminalCode string
  229. CreateTime string
  230. ModifyTime string
  231. ProductNames string `description:"产品名称"`
  232. FromZoneId int `description:"区域ID"`
  233. FromZoneName string `description:"区域名称"`
  234. ToZoneId int `description:"区域ID"`
  235. ToZoneName string `description:"区域名称"`
  236. FlowDirection string `description:"流向"`
  237. Granularity string `description:"粒度"`
  238. Split string `description:"拆分类型"`
  239. }
  240. // AfterFind 在该模型上设置钩子函数,把日期转成正确的string,所以查询函数只能用Find函数,First或者Scan是不会触发该函数的来获取数据
  241. func (m *BaseFromKplerIndexList) AfterFind(db *gorm.DB) (err error) {
  242. m.StartDate = utils.GormDateStrToDateStr(m.StartDate)
  243. m.EndDate = utils.GormDateStrToDateStr(m.EndDate)
  244. return
  245. }
  246. func (y *BaseFromKplerIndex) GetByIndexCodes(indexCodes []string) (list []*BaseFromKplerIndex, err error) {
  247. sql := ` SELECT * FROM base_from_kpler_index WHERE index_code in (?) `
  248. err = global.DEFAULT_DB.Raw(sql, indexCodes).Find(&list).Error
  249. return
  250. }
  251. func (y *BaseFromKplerData) GetByIndexCode(indexCode string) (list []*BaseFromKplerData, err error) {
  252. //o := orm.NewOrm()
  253. sql := ` SELECT * FROM base_from_kpler_data WHERE index_code=? `
  254. //_, err = o.Raw(sql, indexCode).QueryRows(&list)
  255. err = global.DEFAULT_DB.Raw(sql, indexCode).Find(&list).Error
  256. return
  257. }
  258. func (y *BaseFromKplerData) AddMulti(item []*BaseFromKplerData) (err error) {
  259. //o := orm.NewOrm()
  260. //_, err = o.InsertMulti(1, item)
  261. err = global.DEFAULT_DB.CreateInBatches(&item, 1).Error
  262. return
  263. }
  264. // Update 修改
  265. func (y *BaseFromKplerData) Update(updateCols []string) (err error) {
  266. //o := orm.NewOrm()
  267. //_, err = o.Update(y, updateCols...)
  268. err = global.DEFAULT_DB.Model(&y).Select(updateCols).Updates(&y).Error
  269. return
  270. }
  271. // HandleKplerExcelData Kpler的excel数据
  272. type HandleKplerExcelData struct {
  273. ClassifyName string `description:"指标目录"`
  274. ParentClassifyName string `description:"父级指标目录"`
  275. ClassifySort int `description:"指标目录排序号"`
  276. IndexName string `description:"指标名称"`
  277. IndexCode string `description:"指标编码"`
  278. Unit string `description:"单位"`
  279. Sort int `description:"排序号"`
  280. Frequency string `description:"频度"`
  281. ProductNames string `description:"产品名称"`
  282. FromZoneId int `description:"区域ID"`
  283. FromZoneName string `description:"区域名称"`
  284. ToZoneId int `description:"区域ID"`
  285. ToZoneName string `description:"区域名称"`
  286. FlowDirection string `description:"流向"`
  287. Granularity string `description:"粒度"`
  288. Split string `description:"拆分类型"`
  289. ExcelDataMap map[string]string
  290. }
  291. type HandleKplerExcelDataReq struct {
  292. List []*HandleKplerExcelData
  293. TerminalCode string `description:"编码"`
  294. }
  295. func (y *BaseFromKplerData) GetMaxAndMinDateByIndexCode(indexCode string) (item *EdbInfoMaxAndMinInfo, err error) {
  296. //o := orm.NewOrm()
  297. sql := ` SELECT MIN(data_time) AS min_date,MAX(data_time) AS max_date,MIN(value) AS min_value,MAX(value) AS max_value FROM base_from_kpler_data WHERE index_code=? `
  298. //err = o.Raw(sql, indexCode).QueryRow(&item)
  299. err = global.DEFAULT_DB.Raw(sql, indexCode).First(&item).Error
  300. sql = ` SELECT value AS latest_value FROM %s WHERE index_code=? ORDER BY data_time DESC LIMIT 1 `
  301. sql = fmt.Sprintf(sql, "base_from_kpler_data")
  302. //err = o.Raw(sql, indexCode).QueryRow(&latest_value)
  303. var latestValueNull sql2.NullFloat64
  304. err = global.DEFAULT_DB.Raw(sql, indexCode).Scan(&latestValueNull).Error
  305. if err == nil && latestValueNull.Valid {
  306. item.LatestValue = latestValueNull.Float64
  307. }
  308. return
  309. }
  310. func (y *BaseFromKplerIndex) ModifyIndexMaxAndMinDate(indexCode string, item *EdbInfoMaxAndMinInfo) (err error) {
  311. //o := orm.NewOrm()
  312. sql := ` UPDATE base_from_kpler_index SET start_date=?,end_date=?, end_value=?, modify_time=NOW() WHERE index_code=? `
  313. //_, err = o.Raw(sql, item.MinDate, item.MaxDate, item.LatestValue, indexCode).Exec()
  314. err = global.DEFAULT_DB.Exec(sql, item.MinDate, item.MaxDate, item.LatestValue, indexCode).Error
  315. return
  316. }
  317. func (y *BaseFromKplerIndex) GetByIndexCode(indexCode string) (item *BaseFromKplerIndex, err error) {
  318. //o := orm.NewOrm()
  319. sql := ` SELECT * FROM base_from_kpler_index WHERE index_code=? `
  320. //err = o.Raw(sql, indexCode).QueryRow(&item)
  321. err = global.DEFAULT_DB.Raw(sql, indexCode).First(&item).Error
  322. return
  323. }
  324. func (y *BaseFromKplerIndex) Add() (err error) {
  325. //o := orm.NewOrm()
  326. //lastId, err = o.Insert(y)
  327. err = global.DEFAULT_DB.Create(&y).Error
  328. if err != nil {
  329. return
  330. }
  331. return
  332. }
  333. // Update 修改
  334. func (y *BaseFromKplerIndex) Update(updateCols []string) (err error) {
  335. //o := orm.NewOrm()
  336. //_, err = o.Update(y, updateCols...)
  337. err = global.DEFAULT_DB.Model(&y).Select(updateCols).Updates(&y).Error
  338. return
  339. }
  340. func (y *BaseFromKplerClassify) Add() (lastId int64, err error) {
  341. //o := orm.NewOrm()
  342. //lastId, err = o.Insert(y)
  343. err = global.DEFAULT_DB.Create(&y).Error
  344. if err != nil {
  345. return
  346. }
  347. lastId = int64(y.ClassifyId)
  348. return
  349. }
  350. // Update 修改
  351. func (y *BaseFromKplerClassify) Update(updateCols []string) (err error) {
  352. //o := orm.NewOrm()
  353. //_, err = o.Update(y, updateCols...)
  354. err = global.DEFAULT_DB.Model(&y).Select(updateCols).Updates(&y).Error
  355. return
  356. }
  357. func (y *BaseFromKplerClassify) GetByClassifyName(classifyName string) (item *BaseFromKplerClassify, err error) {
  358. //o := orm.NewOrm()
  359. sql := ` SELECT * FROM base_from_kpler_classify WHERE classify_name=? `
  360. //err = o.Raw(sql, classifyName).QueryRow(&item)
  361. err = global.DEFAULT_DB.Raw(sql, classifyName).First(&item).Error
  362. return
  363. }
  364. func (y *BaseFromKplerClassify) GetParentClassify() (items []*BaseFromKplerClassify, err error) {
  365. //o := orm.NewOrm()
  366. sql := ` SELECT * FROM base_from_kpler_classify WHERE parent_id=0 `
  367. //_, err = o.Raw(sql).QueryRows(&items)
  368. err = global.DEFAULT_DB.Raw(sql).Find(&items).Error
  369. return
  370. }
  371. type KplerSearchEdbReq struct {
  372. ProductNames string `description:"产品名称"`
  373. FromZoneIds []int `description:"来源区域ID,对应Location" `
  374. FromZoneNames string `description:"来源区域名称"`
  375. ToZoneIds []int `description:"流向区域ID"`
  376. ToZoneNames string `description:"流向区域名称"`
  377. Split string `description:"拆分类型"`
  378. FlowDirection string `description:"流向,对应periodicity:export/import"`
  379. Granularity string `description:"粒度: daily/weekly/monthly/yearly"`
  380. Unit string `description:"单位"`
  381. }
  382. // withIntraCountry := false
  383. // withIntraRegion := true
  384. // withForecast := true
  385. // withFreightView := false
  386. // withProductEstimation := false
  387. type KplerFlowDataLibReq struct {
  388. Products string `description:"产品名称"`
  389. FromZones string `description:"来源区域ID,对应Location" `
  390. ToZones string `description:"流向区域ID"`
  391. Split string `description:"拆分类型"`
  392. FlowDirection string `description:"流向,对应periodicity:export/import"`
  393. Granularity string `description:"粒度: daily/weekly/monthly/yearly"`
  394. Unit string `description:"单位"`
  395. FromCountries string `description:"来源国家"`
  396. ToCountries string `description:"流向国家"`
  397. FromInstallations string `description:"来源安装"`
  398. ToInstallations string `description:"流向安装"`
  399. OnlyRealized string `description:"是否只查询已实现数据"`
  400. VesselTypes string `description:"船型"`
  401. VesselTypesAlt string `description:"船型"`
  402. WithIntraCountry string `description:"是否查询同国数据"`
  403. WithIntraRegion string `description:"是否查询同区域数据"`
  404. WithForecast string `description:"是否查询预测数据"`
  405. WithFreightView string `description:"是否查询运费数据"`
  406. WithProductEstimation string `description:"是否查询产品估算数据"`
  407. StartDate string `description:"开始日期"`
  408. EndDate string `description:"结束日期"`
  409. }
  410. type KplerFlowDataLibResp struct {
  411. Ret int
  412. Msg string
  413. ErrMsg string
  414. ErrCode string
  415. Data []KplerFlowData
  416. }
  417. type KplerFlowData struct {
  418. SplitItem string
  419. IndexData []KplerIndexDataItem
  420. }
  421. type KplerIndexItem struct {
  422. IndexCode string
  423. IndexName string
  424. Unit string
  425. Frequency string
  426. IndexData []KplerIndexDataItem
  427. }
  428. type KplerIndexDataItem struct {
  429. DataTime string
  430. Value string
  431. }
  432. // BaseFromKplerClassify Kpler原始数据分类表
  433. type BaseFromKplerClassify struct {
  434. ClassifyId int `orm:"column(classify_id);pk" gorm:"primaryKey"`
  435. ClassifyName string `description:"分类名称"`
  436. ParentId int `description:"父级id"`
  437. SysUserId int `description:"创建人id"`
  438. SysUserRealName string `description:"创建人姓名"`
  439. Level int `description:"层级"`
  440. Sort int `description:"排序字段,越小越靠前,默认值:10"`
  441. ModifyTime time.Time `description:"修改时间"`
  442. CreateTime time.Time `description:"创建时间"`
  443. ClassifyNameEn string `description:"英文分类名称"`
  444. ProductId int `description:"产品ID"`
  445. ProductName string `description:"产品名称"`
  446. AncestorFamilyId int `description:"父级产品ID"`
  447. AncestorFamilyName string `description:"父级产品名称"`
  448. AncestorGroupId int `description:"父级产品ID"`
  449. AncestorGroupName string `description:"父级产品名称"`
  450. AncestorProductId int `description:"父级产品ID"`
  451. AncestorProductName string `description:"父级产品名称"`
  452. AncestorGradeId int `description:"父级产品ID"`
  453. AncestorGradeName string `description:"父级产品名称"`
  454. ClassifyType string `description:"分类类型"`
  455. }
  456. func GetAllBaseFromKplerClassify() (items []*BaseFromKplerClassify, err error) {
  457. sql := ` SELECT * FROM base_from_kpler_classify `
  458. err = global.DEFAULT_DB.Raw(sql).Find(&items).Error
  459. return
  460. }
  461. // 获取分类
  462. func (y *BaseFromKplerClassify) GetByProductIds(productIds []int) (items []*BaseFromKplerClassify, err error) {
  463. sql := ` SELECT * FROM base_from_kpler_classify WHERE product_id in (?) `
  464. err = global.DEFAULT_DB.Raw(sql, productIds).Find(&items).Error
  465. return
  466. }
  467. // 获取区域
  468. // BaseFromKplerZone Kpler区域表
  469. type BaseFromKplerZone struct {
  470. BaseFromKplerZoneId int `orm:"column(base_from_kpler_zone_id);pk" gorm:"primaryKey"`
  471. ZoneName string `description:"区域名称"`
  472. ZoneType string `description:"区域类型"`
  473. ParentId int `description:"区域父ID"`
  474. AncestorId int `description:"区域祖先ID"`
  475. AncestorType string `description:"区域祖先类型"`
  476. AncestorName string `description:"区域祖先名称"`
  477. DescendantId int `description:"区域子ID"`
  478. DescendantName string `description:"区域子名称"`
  479. CreateTime time.Time `description:"创建时间"`
  480. ModifyTime time.Time `description:"修改时间"`
  481. }
  482. // 获取区域
  483. func (y *BaseFromKplerZone) GetByZoneIds(zoneIds []int) (items []*BaseFromKplerZone, err error) {
  484. sql := ` SELECT * FROM base_from_kpler_zone WHERE base_from_kpler_zone_id in (?) `
  485. err = global.DEFAULT_DB.Raw(sql, zoneIds).Find(&items).Error
  486. return
  487. }
  488. func (y *BaseFromKplerZone) Add() (lastId int64, err error) {
  489. err = global.DEFAULT_DB.Create(&y).Error
  490. if err != nil {
  491. return
  492. }
  493. lastId = int64(y.BaseFromKplerZoneId)
  494. return
  495. }
  496. type KplerProductLibResp struct {
  497. Ret int
  498. Msg string
  499. ErrMsg string
  500. ErrCode string
  501. Data []KplerProduct
  502. }
  503. //bodystr := "Id (Product);Name;Type (Product);Family;Family Id;Group;Group Id;Product;Product Id;Grade;Grade Id;Density (Product);Density Unit;Energy Density;Energy Density Unit;Expansion Ratio
  504. type KplerProduct struct {
  505. Id string
  506. Name string
  507. Type string
  508. Family string
  509. FamilyId string
  510. Group string
  511. GroupId string
  512. Product string
  513. ProductId string
  514. Grade string
  515. GradeId string
  516. Density string
  517. DensityUnit string
  518. EnergyDensity string
  519. EnergyDensityUnit string
  520. ExpansionRatio string
  521. }
  522. type KplerZoneLibResp struct {
  523. Ret int
  524. Msg string
  525. ErrMsg string
  526. ErrCode string
  527. Data []KplerZone
  528. }
  529. // Ancestor Id;Ancestor Name;Ancestor Type;Descendant Id;Descendant Name;Descendant Type
  530. type KplerZone struct {
  531. AncestorId string
  532. AncestorName string
  533. AncestorType string
  534. DescendantId string
  535. DescendantName string
  536. }
  537. type KplerZoneDataLibReq struct {
  538. AncestorName string `description:"祖先名称"`
  539. DescendantName string `description:"子名称"`
  540. }