1 Star 0 Fork 0

kzangv / gsf-excel

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
upload.go 1.60 KB
一键复制 编辑 原始数据 按行查看 历史
kzangv 提交于 2023-12-25 10:17 . fixed
package gexcel
import (
"bytes"
"errors"
"regexp"
"strings"
)
type _CommonFileHandle struct {
sh SheetHandle
}
func (p *_CommonFileHandle) Each(name string, idx int) (SheetHandle, error) {
if idx > 0 {
return nil, SheetIgnore
}
return p.sh, nil
}
func NewFileHandle(sh SheetHandle) FileHandle {
return &_CommonFileHandle{sh: sh}
}
func Trim(val string) string {
return strings.Trim(val, trimChar)
}
func NumberRemoveComma(val string) string {
return strings.ReplaceAll(val, ",", "")
}
func FormatDate(val string) string {
if val == "" {
return val
}
if match, _ := regexp.MatchString(`^\d{4}-\d{1,2}-\d{1,2}$`, val); match {
dVals := strings.Split(val, "-")
if len(dVals[1]) < 2 {
dVals[1] = "0" + dVals[1]
}
if len(dVals[2]) < 2 {
dVals[2] = "0" + dVals[2]
}
return strings.Join(dVals, "-")
} else if match, _ = regexp.MatchString(`^\d{4}/\d{1,2}/\d{1,2}$`, val); match {
dVals := strings.Split(val, "/")
if len(dVals[1]) < 2 {
dVals[1] = "0" + dVals[1]
}
if len(dVals[2]) < 2 {
dVals[2] = "0" + dVals[2]
}
return strings.Join(dVals, "-")
} else if match, _ = regexp.MatchString(`^\d{4}\d{2}\d{2}$`, val); match {
return val[0:4] + "-" + val[4:6] + "-" + val[6:8]
}
return ""
}
func Parse(ft string, buf *bytes.Buffer, h FileHandle, ignore bool, fps ...FileParse) *ParseError {
if len(fps) == 0 {
fps = defaultParsers
}
for _, v := range fps {
if v.Type() == ft {
if err := v.Init(buf); err != nil {
return err
}
if v.Len() > 0 {
return v.Parse(h, ignore)
}
return nil
}
}
return &ParseError{Err: errors.New("文件格式错误")}
}
Go
1
https://gitee.com/kzangv/gsf-excel.git
git@gitee.com:kzangv/gsf-excel.git
kzangv
gsf-excel
gsf-excel
v0.0.4

搜索帮助

53164aa7 5694891 3bd8fe86 5694891