123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342 |
- package excel
- import (
- "encoding/json"
- "fmt"
- "reflect"
- "strconv"
- )
- type LuckySheetDataBak struct {
- CalcChain []interface{} `json:"calcChain" description:"公式链"`
- CellData []LuckySheetCellData `json:"celldata" description:"单元格数据"`
- ChWidth int64 `json:"ch_width" description:"工作表区域的宽度"`
- Config struct {
- BorderInfo []struct {
- BorderType string `json:"borderType" description:""`
- Color string `json:"color" description:""`
- Range []struct {
- Column []int64 `json:"column" description:""`
- Row []int64 `json:"row" description:""`
- } `json:"range" description:""`
- RangeType string `json:"rangeType" description:""`
- Style string `json:"style" description:""`
- Value struct {
- B struct {
- Color string `json:"color" description:""`
- Style string `json:"style" description:""`
- } `json:"b" description:""`
- ColIndex int64 `json:"col_index" description:""`
- L struct {
- Color string `json:"color" description:""`
- Style string `json:"style" description:""`
- } `json:"l" description:""`
- R struct {
- Color string `json:"color" description:""`
- Style string `json:"style" description:""`
- } `json:"r" description:""`
- RowIndex int64 `json:"row_index" description:""`
- T struct {
- Color string `json:"color" description:""`
- Style string `json:"style" description:""`
- } `json:"t" description:""`
- } `json:"value" description:"" description:""`
- } `json:"borderInfo" description:""`
- Colhidden struct{} `json:"colhidden" description:""`
- Columnlen map[string]float64 `json:"columnlen" description:""`
- CustomHeight struct {
- Zero int64 `json:"0"`
- } `json:"customHeight" description:""`
- CustomWidth struct {
- Two int64 `json:"2" description:""`
- } `json:"customWidth" description:""`
- Merge struct{} `json:"merge" description:""`
- Rowlen map[string]float64 `json:"rowlen" description:""`
- } `json:"config" description:""`
- Data [][]struct {
- Ct struct {
- Fa string `json:"fa"`
- T string `json:"t"`
- } `json:"ct"`
- M string `json:"m"`
- V interface{} `json:"v"`
- } `json:"data" description:""`
- DataVerification struct{} `json:"dataVerification" description:""`
- Filter interface{} `json:"filter" description:""`
- FilterSelect interface{} `json:"filter_select" description:""`
- Hyperlink struct{} `json:"hyperlink" description:""`
- Images struct{} `json:"images" description:""`
- Index string `json:"index" description:""`
- JfgirdSelectSave []interface{} `json:"jfgird_select_save" description:""`
- LuckysheetAlternateformatSave []interface{} `json:"luckysheet_alternateformat_save" description:""`
- LuckysheetConditionformatSave []interface{} `json:"luckysheet_conditionformat_save" description:""`
- LuckysheetSelectSave []struct {
- Column []int64 `json:"column" description:""`
- ColumnFocus int64 `json:"column_focus" description:""`
- Height int64 `json:"height" description:""`
- HeightMove int64 `json:"height_move" description:""`
- Left int64 `json:"left" description:""`
- LeftMove int64 `json:"left_move" description:""`
- Row []int64 `json:"row" description:""`
- RowFocus int64 `json:"row_focus" description:""`
- Top int64 `json:"top" description:""`
- TopMove int64 `json:"top_move" description:""`
- Width int64 `json:"width" description:""`
- WidthMove int64 `json:"width_move" description:""`
- } `json:"luckysheet_select_save" description:"" description:""`
- LuckysheetSelectionRange []struct {
- Column []int64 `json:"column" description:""`
- Row []int64 `json:"row" description:""`
- } `json:"luckysheet_selection_range" description:""`
- RhHeight float64 `json:"rh_height" description:""`
- ScrollLeft float64 `json:"scrollLeft" description:""`
- ScrollTop float64 `json:"scrollTop" description:""`
- Status int64 `json:"status" description:""`
- Visibledatacolumn []int64 `json:"visibledatacolumn" description:""`
- Visibledatarow []int64 `json:"visibledatarow" description:""`
- ZoomRatio float64 `json:"zoomRatio" description:"sheet缩放比例"`
- }
- // LuckySheetData sheet表格数据
- type LuckySheetData struct {
- CellData []LuckySheetCellData `json:"celldata" description:"单元格数据"`
- ChWidth int64 `json:"ch_width" description:"工作表区域的宽度"`
- Config LuckySheetDataConfig `json:"config" description:""`
- //Index int `json:"index" description:"工作表索引"`
- RhHeight float64 `json:"rh_height" description:"工作表区域的高度"`
- ScrollLeft float64 `json:"scrollLeft" description:"左右滚动条位置"`
- ScrollTop float64 `json:"scrollTop" description:"上下滚动条位置"`
- Status interface{} `json:"status" description:"激活状态"`
- VisibleDataColumn []int64 `json:"visibledatacolumn" description:"所有列的位置信息,递增的列位置数据,初始化无需设置"`
- VisibleDataRow []int64 `json:"visibledatarow" description:"所有行的位置信息,递增的行位置数据,初始化无需设置"`
- ZoomRatio float64 `json:"zoomRatio" description:"sheet缩放比例"`
- }
- // LuckySheetDataConfig sheet表单的配置
- type LuckySheetDataConfig struct {
- BorderInfo []LuckySheetDataConfigBorderInfo `json:"borderInfo" description:"边框"`
- Colhidden map[string]int64 `json:"colhidden" description:"隐藏列,示例值:\"colhidden\":{\"30\":0,\"31\":0}"`
- Columnlen map[string]float64 `json:"columnlen" description:"每个单元格的列宽"`
- //CustomHeight struct {
- // Zero int64 `json:"0"`
- //} `json:"customHeight" description:""`
- //CustomWidth struct {
- // Two int64 `json:"2" description:""`
- //} `json:"customWidth" description:""`
- Merge map[string]LuckySheetDataConfigMerge `json:"merge" description:"合并单元格"`
- Rowlen map[string]float64 `json:"rowlen" description:"每个单元格的行高"`
- }
- // LuckySheetDataConfigMerge 合并单元格设置
- type LuckySheetDataConfigMerge struct {
- Row int `json:"r" description:"行数"`
- Column int `json:"c" description:"列数"`
- Rs int `json:"rs" description:"合并的行数"`
- Cs int `json:"cs" description:"合并的列数"`
- }
- // LuckySheetDataConfigBorderInfo 单元格边框信息
- type LuckySheetDataConfigBorderInfo struct {
- BorderType string `json:"borderType" description:"边框类型 border-left | border-right | border-top | border-bottom | border-all | border-outside | border-inside | border-horizontal | border-vertical | border-none"`
- Color string `json:"color" description:"边框颜色 color: 16进制颜色值"`
- Range []struct {
- Column []int64 `json:"column" description:"行"`
- Row []int64 `json:"row" description:"列"`
- } `json:"range" description:"选区范围 range: 行列信息数组"`
- RangeType string `json:"rangeType" description:"选区 rangeType: range | cell "`
- Style string `json:"style" description:"边框粗细 style: 1 Thin | 2 Hair | 3 Dotted | 4 Dashed | 5 DashDot | 6 DashDotDot | 7 Double | 8 Medium | 9 MediumDashed | 10 MediumDashDot | 11 MediumDashDotDot | 12 SlantedDashDot | 13 Thick ,和aspose.cells的getLineStyle()的值对应的话,需要自己做个转换,参考 aspose.cells"`
- Value LuckySheetDataConfigBorderInfoCellValue `json:"value" description:"" description:"范围类型分单个单元格的数据"`
- }
- // LuckySheetDataConfigBorderInfoCellValue 单元格边框信息(范围类型为:单个单元格)
- type LuckySheetDataConfigBorderInfoCellValue struct {
- B LuckySheetDataConfigBorderInfoCell `json:"b" description:"下边框"`
- L LuckySheetDataConfigBorderInfoCell `json:"l" description:"左边框"`
- R LuckySheetDataConfigBorderInfoCell `json:"r" description:"右边框"`
- T LuckySheetDataConfigBorderInfoCell `json:"t" description:"上边框"`
- ColIndex int64 `json:"col_index" description:"第几行"`
- RowIndex int64 `json:"row_index" description:"第几列"`
- }
- // LuckySheetDataConfigBorderInfoCell 单元格边框信息(cell类型)
- type LuckySheetDataConfigBorderInfoCell struct {
- Color string `json:"color" description:"边框颜色 color: 16进制颜色值"`
- Style int `description:"边框粗细 style: 1 Thin | 2 Hair | 3 Dotted | 4 Dashed | 5 DashDot | 6 DashDotDot | 7 Double | 8 Medium | 9 MediumDashed | 10 MediumDashDot | 11 MediumDashDotDot | 12 SlantedDashDot | 13 Thick ,和aspose.cells的getLineStyle()的值对应的话,需要自己做个转换,参考 aspose.cells"`
- Sl interface{} `json:"style" description:"边框粗细 style: 1 Thin | 2 Hair | 3 Dotted | 4 Dashed | 5 DashDot | 6 DashDotDot | 7 Double | 8 Medium | 9 MediumDashed | 10 MediumDashDot | 11 MediumDashDotDot | 12 SlantedDashDot | 13 Thick ,和aspose.cells的getLineStyle()的值对应的话,需要自己做个转换,参考 aspose.cells"`
- }
- // LuckySheetCellData 单个单元格数据
- type LuckySheetCellData struct {
- Col int64 `json:"c" description:"列"`
- Row int64 `json:"r" description:"行"`
- Value LuckySheetDataValue `json:"v" description:"单元格内值的数据"`
- }
- // LuckySheetDataValue 单元格内值的数据
- type LuckySheetDataValue struct {
- CellType LuckySheetDataCellType `json:"ct" description:"单元格值格式:文本、时间等 "`
- Value interface{} `json:"v" description:"原始值"`
- Monitor string `json:"m" description:"显示值"`
- Background string `json:"bg" description:"背景色,实例值:#fff000"`
- FontFamily int `description:"字体,0 Times New Roman、 1 Arial、2 Tahoma 、3 Verdana、4 微软雅黑、5 宋体(Song)、6 黑体(ST Heiti)、7 楷体(ST Kaiti)、 8 仿宋(ST FangSong)、9 新宋体(ST Song)、10 华文新魏、11 华文行楷、12 华文隶书 "`
- FF interface{} `json:"ff" description:"字体,0 Times New Roman、 1 Arial、2 Tahoma 、3 Verdana、4 微软雅黑、5 宋体(Song)、6 黑体(ST Heiti)、7 楷体(ST Kaiti)、 8 仿宋(ST FangSong)、9 新宋体(ST Song)、10 华文新魏、11 华文行楷、12 华文隶书 "`
- FontColor string `json:"fc" description:"字体颜色,示例值:#fff000" `
- Bold int `json:"bl" description:"粗体,0 常规 、 1加粗 "`
- Italic int `json:"it" description:"斜体,0 常规 、 1 斜体"`
- Fontsize int `description:"字体大小,14"`
- CancelLine int ` description:"删除线, 0 常规 、 1 删除线"`
- HorizontalType int `description:"水平对齐, 0 居中、1 左、2右"`
- VerticalType int ` description:"垂直对齐, 0 中间、1 上、2下"`
- Fs interface{} `json:"fs" description:"字体大小,14"`
- Cl interface{} `json:"cl" description:"删除线, 0 常规 、 1 删除线"`
- Ht interface{} `json:"ht" description:"水平对齐, 0 居中、1 左、2右"`
- Vt interface{} `json:"vt" description:"垂直对齐, 0 中间、1 上、2下"`
- //TextRotate string `json:"tr" description:"竖排文字, 3"`
- //RotateText string `json:"rt" description:"文字旋转角度, 介于0~180之间的整数,包含0和180"`
- TextBeak int `description:"文本换行, 0 截断、1溢出、2 自动换行"`
- Tb interface{} `json:"tb" description:"文本换行, 0 截断、1溢出、2 自动换行"`
- Ps LuckySheetDataCellComment `json:"ps" description:"批注"`
- Function string `json:"f" description:"公式"`
- MergeCell LuckySheetDataConfigMerge `json:"mc" description:"合并单元格信息"`
- }
- // LuckySheetDataCellType 单元格值格式:文本、时间等
- type LuckySheetDataCellType struct {
- Fa string `json:"fa" description:"格式名称,例如:“General”为自动格式"`
- T string `json:"t" description:"格式类型,例如:“n”为数字类型"`
- S []struct {
- FontFamily int `description:"字体,0 Times New Roman、 1 Arial、2 Tahoma 、3 Verdana、4 微软雅黑、5 宋体(Song)、6 黑体(ST Heiti)、7 楷体(ST Kaiti)、 8 仿宋(ST FangSong)、9 新宋体(ST Song)、10 华文新魏、11 华文行楷、12 华文隶书 "`
- FF interface{} `json:"ff" description:"字体,0 Times New Roman、 1 Arial、2 Tahoma 、3 Verdana、4 微软雅黑、5 宋体(Song)、6 黑体(ST Heiti)、7 楷体(ST Kaiti)、 8 仿宋(ST FangSong)、9 新宋体(ST Song)、10 华文新魏、11 华文行楷、12 华文隶书 "`
- FontColor string `json:"fc" description:"字体颜色,示例值:#fff000" `
- Fontsize int `description:"字体大小,14"`
- CancelLine int ` description:"删除线, 0 常规 、 1 删除线"`
- HorizontalType int `description:"水平对齐, 0 居中、1 左、2右"`
- VerticalType int `description:"垂直对齐, 0 中间、1 上、2下"`
- Fs interface{} `json:"fs" description:"字体大小,14"`
- Cl interface{} `json:"cl" description:"删除线, 0 常规 、 1 删除线"`
- Ht interface{} `json:"ht" description:"水平对齐, 0 居中、1 左、2右"`
- Vt interface{} `json:"vt" description:"垂直对齐, 0 中间、1 上、2下"`
- Un interface{} `json:"un" description:""`
- Bold interface{} `json:"bl" description:"粗体,0 常规 、 1加粗 "`
- Italic interface{} `json:"it" description:"斜体,0 常规 、 1 斜体"`
- Value interface{} `json:"v" description:"原始值"`
- } `json:"s"`
- }
- // LuckySheetDataCellComment 批注
- type LuckySheetDataCellComment struct {
- Left int `json:"left" description:"批注框距离左边工作表边缘位置"`
- Top int `json:"top" description:"批注框距离上边工作表边缘位置"`
- Width int `json:"width" description:"批注框宽度"`
- Height int `json:"height" description:"批注框高度"`
- Value string `json:"value" description:"批注内容"`
- IsShow bool `json:"isshow" description:"是否显示批注"`
- }
- // GetLuckySheetData 获取LuckySheetData的结构体
- func GetLuckySheetData(jsonStr string) (item *LuckySheetData, err error) {
- err = json.Unmarshal([]byte(jsonStr), &item)
- for k, v := range item.CellData {
- value := v.Value
- value.Fontsize = getIntValueByInterface(value.Fs)
- value.CancelLine = getIntValueByInterface(value.Cl)
- value.HorizontalType = getIntValueByInterface(value.Ht)
- value.VerticalType = getIntValueByInterface(value.Vt)
- value.FontFamily = getIntValueByInterface(value.FF)
- value.TextBeak = getIntValueByInterface(value.Tb)
- if len(value.CellType.S) > 0 {
- for kk, vv := range value.CellType.S {
- vv.Fontsize = getIntValueByInterface(vv.Fs)
- vv.CancelLine = getIntValueByInterface(vv.Cl)
- vv.HorizontalType = getIntValueByInterface(vv.Ht)
- vv.VerticalType = getIntValueByInterface(vv.Vt)
- vv.FontFamily = getIntValueByInterface(vv.FF)
- value.CellType.S[kk] = vv
- }
- }
- item.CellData[k].Value = value
- }
- //边框
- if len(item.Config.BorderInfo) > 0 {
- for k, v := range item.Config.BorderInfo {
- v.Value.T.Style = getIntValueByInterface(v.Value.T.Style)
- v.Value.B.Style = getIntValueByInterface(v.Value.B.Style)
- v.Value.L.Style = getIntValueByInterface(v.Value.L.Style)
- v.Value.R.Style = getIntValueByInterface(v.Value.R.Style)
- item.Config.BorderInfo[k] = v
- }
- }
- return
- }
- // 兼容前端js传递的数据类型
- func getIntValueByInterface(valInterface interface{}) (val int) {
- if valInterface == nil {
- return
- }
- switch reflect.TypeOf(valInterface).Kind() {
- case reflect.String:
- tmpValue := reflect.ValueOf(valInterface).String()
- tmpValInt, err := strconv.Atoi(tmpValue)
- if err != nil {
- val = 0
- } else {
- val = tmpValInt
- }
- case reflect.Int, reflect.Int32, reflect.Int64:
- tmpValue := reflect.ValueOf(valInterface).Int()
- val = int(tmpValue)
- }
- return
- }
- // TableData 表格数据
- type TableData struct {
- TableDataList [][]LuckySheetDataValue
- RowWidthList []float64
- RowHeightList []float64
- RemoveTopRow int `description:"移除表格上方的行数"`
- RemoveBottomRow int `description:"移除表格下方的行数"`
- RemoveLeftColumn int `description:"移除表格左侧的列数"`
- RemoveRightColumn int `description:"移除表格右侧的列数"`
- MergeList []TableDataMerge `description:"合并数据列"`
- }
- // TableDataMerge 表格数据合并单元格配置
- type TableDataMerge struct {
- StartRowIndex int `json:"start_row_index" description:"开始的行下标"`
- StartColumnIndex int `json:"start_column" description:"开始的列下标"`
- MergeRowNum int `json:"merge_row_num" description:"合并的行数"`
- MergeColumnNum int `json:"merge_column_num" description:"合并的列数"`
- }
- // TableRemoveNum 上下左右移除的空行空列数量
- type TableRemoveNum struct {
- RemoveTopRow int `description:"移除表格上方的行数"`
- RemoveBottomRow int `description:"移除表格下方的行数"`
- RemoveLeftColumn int `description:"移除表格左侧的列数"`
- RemoveRightColumn int `description:"移除表格右侧的列数"`
- }
- // handleCellVal 处理单元格数据
- func handleCellVal(tmpTableColData LuckySheetDataValue) (valueStr string) {
- valueStr = tmpTableColData.Monitor
- if valueStr == `` {
- //valueStr = fmt.Sprint(cellInfo.Value)
- if valueStr == `` && tmpTableColData.CellType.S != nil {
- //不是设置在单元格上面,而是设置在文本上
- for _, cellS := range tmpTableColData.CellType.S {
- valueStr += fmt.Sprint(cellS.Value)
- }
- }
- }
- return
- }
- type CellPosition struct {
- RowIndex int
- ColumnIndex int
- }
|