Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xuri
excelize
提交
9b55f4f9
excelize
项目概览
xuri
/
excelize
通知
13
Star
2
Fork
4
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
excelize
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
9b55f4f9
编写于
8月 21, 2021
作者:
S
Stani
提交者:
GitHub
8月 21, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
This closes #1006, new fn: MONTH ref #65
Co-authored-by:
xuri
<
xuri.me@gmail.com
>
上级
4d716fa7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
45 addition
and
1 deletion
+45
-1
calc.go
calc.go
+31
-0
calc_test.go
calc_test.go
+14
-1
未找到文件。
calc.go
浏览文件 @
9b55f4f9
...
...
@@ -504,6 +504,7 @@ type formulaFuncs struct {
// VAR.P
// VARP
// VLOOKUP
// YEAR
//
func
(
f
*
File
)
CalcCellValue
(
sheet
,
cell
string
)
(
result
string
,
err
error
)
{
var
(
...
...
@@ -6445,6 +6446,36 @@ func (fn *formulaFuncs) MONTH(argsList *list.List) formulaArg {
return
newNumberFormulaArg
(
float64
(
timeFromExcelTime
(
num
.
Number
,
false
)
.
Month
()))
}
// YEAR function returns an integer representing the year of a supplied date.
// The syntax of the function is:
//
// YEAR(serial_number)
//
func
(
fn
*
formulaFuncs
)
YEAR
(
argsList
*
list
.
List
)
formulaArg
{
if
argsList
.
Len
()
!=
1
{
return
newErrorFormulaArg
(
formulaErrorVALUE
,
"YEAR requires exactly 1 argument"
)
}
arg
:=
argsList
.
Front
()
.
Value
.
(
formulaArg
)
num
:=
arg
.
ToNumber
()
if
num
.
Type
!=
ArgNumber
{
dateString
:=
strings
.
ToLower
(
arg
.
Value
())
if
!
isDateOnlyFmt
(
dateString
)
{
if
_
,
_
,
_
,
_
,
_
,
err
:=
strToTime
(
dateString
);
err
.
Type
==
ArgError
{
return
err
}
}
year
,
_
,
_
,
_
,
err
:=
strToDate
(
dateString
)
if
err
.
Type
==
ArgError
{
return
err
}
return
newNumberFormulaArg
(
float64
(
year
))
}
if
num
.
Number
<
0
{
return
newErrorFormulaArg
(
formulaErrorNUM
,
"YEAR only accepts positive argument"
)
}
return
newNumberFormulaArg
(
float64
(
timeFromExcelTime
(
num
.
Number
,
false
)
.
Year
()))
}
// NOW function returns the current date and time. The function receives no
// arguments and therefore. The syntax of the function is:
//
...
...
calc_test.go
浏览文件 @
9b55f4f9
...
...
@@ -965,6 +965,13 @@ func TestCalcCellValue(t *testing.T) {
// MONTH
"=MONTH(42171)"
:
"6"
,
"=MONTH(
\"
31-May-2015
\"
)"
:
"5"
,
// YEAR
"=YEAR(15)"
:
"1900"
,
"=YEAR(
\"
15
\"
)"
:
"1900"
,
"=YEAR(2048)"
:
"1905"
,
"=YEAR(42171)"
:
"2015"
,
"=YEAR(
\"
29-May-2015
\"
)"
:
"2015"
,
"=YEAR(
\"
05/03/1984
\"
)"
:
"1984"
,
// Text Functions
// CHAR
"=CHAR(65)"
:
"A"
,
...
...
@@ -1986,10 +1993,16 @@ func TestCalcCellValue(t *testing.T) {
"=DAY(
\"
0-January-1900
\"
)"
:
"#VALUE!"
,
// MONTH
"=MONTH()"
:
"MONTH requires exactly 1 argument"
,
"=MONTH(
43891,43101)"
:
"MONTH requires exactly 1 argument"
,
"=MONTH(
0,0)"
:
"MONTH requires exactly 1 argument"
,
"=MONTH(-1)"
:
"MONTH only accepts positive argument"
,
"=MONTH(
\"
text
\"
)"
:
"#VALUE!"
,
"=MONTH(
\"
January 25, 100
\"
)"
:
"#VALUE!"
,
// YEAR
"=YEAR()"
:
"YEAR requires exactly 1 argument"
,
"=YEAR(0,0)"
:
"YEAR requires exactly 1 argument"
,
"=YEAR(-1)"
:
"YEAR only accepts positive argument"
,
"=YEAR(
\"
text
\"
)"
:
"#VALUE!"
,
"=YEAR(
\"
January 25, 100
\"
)"
:
"#VALUE!"
,
// NOW
"=NOW(A1)"
:
"NOW accepts no arguments"
,
// TODAY
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录