package excel import ( "github.com/beego/beego/v2/client/orm" "time" ) // ExcelInfo excel表格详情表 type ExcelInfo struct { ExcelInfoId int `orm:"column(excel_info_id);pk"` Source int `description:"表格来源,1:excel插件的表格,2:自定义表格,3:混合表格,4:自定义分析,默认:1"` ExcelType int `description:"表格类型,1:指标列,2:日期列,默认:1"` ExcelName string `description:"表格名称"` UniqueCode string `description:"表格唯一编码"` ExcelClassifyId int `description:"表格分类id"` SysUserId int `description:"操作人id"` SysUserRealName string `description:"操作人真实姓名"` Content string `description:"表格内容"` ExcelImage string `description:"表格图片"` FileUrl string `description:"表格下载地址"` Sort int `description:"排序字段,数字越小越排前面"` IsDelete int `description:"是否删除,0:未删除,1:已删除"` ModifyTime time.Time `description:"最近修改日期"` CreateTime time.Time `description:"创建日期"` IsJoinPermission int `description:"是否加入权限管控,0:不加入;1:加入;默认:0"` ParentId int `description:"表格的父级id"` BalanceType int `description:"平衡表类型:0 动态表,1静态表"` UpdateUserId int `description:"更新人id"` UpdateUserRealName string `description:"更新人真实姓名"` RelExcelInfoId int `description:"平衡表里静态表关联的动态表excel id"` VersionName string `description:"静态表版本名称"` SourcesFrom string `description:"图表来源"` ExtraConfig string `description:"额外配置:如多空分析、相关性表格参数"` } // GetNoContentExcelInfoAll 获取不含content的表格列表 用于分类展示 func GetNoContentExcelInfoAll(source, userId int) (items []*ExcelClassifyItems, err error) { o := orm.NewOrm() sql := ` SELECT excel_info_id,excel_classify_id,excel_name AS excel_classify_name, unique_code,sys_user_id,sys_user_real_name FROM excel_info where is_delete=0 AND source = ? ` pars := []interface{}{source} if userId > 0 { sql += ` AND sys_user_id = ? ` pars = append(pars, userId) } sql += ` ORDER BY sort asc,create_time desc ` _, err = o.Raw(sql, pars...).QueryRows(&items) return } // UpdateExcelInfoClassifyId 更改表格分类 func UpdateExcelInfoClassifyId(classifyId, excelInfoId int) (err error) { o := orm.NewOrm() sql := ` update excel_info set excel_classify_id = ? WHERE excel_info_id=? ` _, err = o.Raw(sql, classifyId, excelInfoId).Exec() return } // GetAllExcelInfoBySource 根据来源获取包含content的表格列表 func GetAllExcelInfoBySource(source int) (items []*ExcelInfo, err error) { o := orm.NewOrm() sql := ` SELECT * FROM excel_info where is_delete=0 AND source = ? ORDER BY sort asc,create_time desc ` _, err = o.Raw(sql, source).QueryRows(&items) return } // TableDataReq 自定义表格请求参数 type TableDataReq struct { EdbInfoIdList []int `description:"指标id列表,从左至右,从上到下的顺序"` Sort int `description:"日期排序,1:倒序,2:正序"` Data []EdbInfoData `description:"数据列表"` TextRowData [][]ManualDataReq `description:"文本列表"` } // EdbInfoData 自定义表格的数据 type EdbInfoData struct { EdbInfoId int `description:"指标ID"` Tag string `description:"标签"` EdbName string `description:"指标名称"` EdbAliasName string `description:"指标别名"` Frequency string `description:"频度"` Unit string `description:"单位"` Data []ManualDataReq `description:"单元格数据列表"` } // ManualDataReq 自定义表格的单元格数据 type ManualDataReq struct { DataType int `description:"数据类型,1:普通的,2:插值法,3:手动输入,4:公式计算,5:预测值"` DataTime string `description:"所属日期"` DataTimeType int `description:"日期类型,1:实际日期;2:未来日期"` ShowValue string `description:"展示值"` Value string `description:"实际值(计算公式)"` RelationEdbInfoList []RelationEdbInfo `description:"关联指标(计算公式中关联的指标,用于计算的时候去匹配)"` } // RelationEdbInfo 自定义表格中单元格的关联指标 type RelationEdbInfo struct { Tag string `description:"指标标签"` Row string `description:"第几行"` } // MixedTableReq 混合表格保存请求参数 type MixedTableReq struct { CellRelation string `description:"单元格关系"` Data [][]MixedTableCellDataReq `description:"混合表格单元格参数"` } // MixedTableCellDataReq 混合表格单元格参数 type MixedTableCellDataReq struct { Uid string `description:"单元格唯一标识"` DataType int `description:"数据类型,1:日期,2:指标,3:自定义文本,4:插值"` DataTime string `description:"所属日期"` DataTimeType int `description:"日期类型:0:手动输入日期;1:导入系统日期;;3:导入指标日期(指标库的最新日期);"` EdbInfoId int `description:"指标id"` ShowValue string `description:"展示值"` Value string `description:"实际值"` } func (m *ExcelInfo) Update(cols []string) (err error) { o := orm.NewOrm() _, err = o.Update(m, cols...) return } func (m *ExcelInfo) GetItemById(id int) (item *ExcelInfo, err error) { o := orm.NewOrm() sql := `SELECT * FROM excel_info WHERE excel_info_id = ? LIMIT 1` err = o.Raw(sql, id).QueryRow(&item) return }