开源 企业版 高校版 私有云 模力方舟 AI 队友
代码拉取完成,页面将自动刷新
捐赠
捐赠前请先登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
3 Star 4 Fork 4

ToolGood/ToolGood.Algorithm

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
已有帐号? 立即登录
文件
master
分支 (7)
标签 (27)
master
js-dev
java-dev
Fast
v3.5
v2.x
v1.x
6.0.0.8
6.0.0.0
5.0.0.2
3.5.0.3
3.4.1.4
3.4.1.3
3.4.0.0
3.3.0.0
3.2.0.2
3.2.0.1
3.0.3
3.0.2
3.0.1
3.0.0.0
2.2.0.2
2.2.0.1-java
2.2.0.1
2.2
2.1.0.1
2.1
master
分支 (7)
标签 (27)
master
js-dev
java-dev
Fast
v3.5
v2.x
v1.x
6.0.0.8
6.0.0.0
5.0.0.2
3.5.0.3
3.4.1.4
3.4.1.3
3.4.0.0
3.3.0.0
3.2.0.2
3.2.0.1
3.0.3
3.0.2
3.0.1
3.0.0.0
2.2.0.2
2.2.0.1-java
2.2.0.1
2.2
2.1.0.1
2.1
克隆/下载
克隆/下载
提示
下载代码请复制以下命令到终端执行
为确保你提交的代码身份被 Gitee 正确识别,请执行以下命令完成配置
初次使用 SSH 协议进行代码克隆、推送等操作时,需按下述提示完成 SSH 配置
1 生成 RSA 密钥
2 获取 RSA 公钥内容,并配置到 SSH公钥
在 Gitee 上使用 SVN,请访问 使用指南
使用 HTTPS 协议时,命令行会出现如下账号密码验证步骤。基于安全考虑,Gitee 建议 配置并使用私人令牌 替代登录密码进行克隆、推送等操作
Username for 'https://gitee.com': userName
Password for 'https://userName@gitee.com': # 私人令牌
master
分支 (7)
标签 (27)
master
js-dev
java-dev
Fast
v3.5
v2.x
v1.x
6.0.0.8
6.0.0.0
5.0.0.2
3.5.0.3
3.4.1.4
3.4.1.3
3.4.0.0
3.3.0.0
3.2.0.2
3.2.0.1
3.0.3
3.0.2
3.0.1
3.0.0.0
2.2.0.2
2.2.0.1-java
2.2.0.1
2.2
2.1.0.1
2.1
ToolGood.Algorithm
/
JavaScript
/
tests
/
CalculateTreeTest.js
ToolGood.Algorithm
/
JavaScript
/
tests
/
CalculateTreeTest.js
CalculateTreeTest.js 4.08 KB
一键复制 编辑 原始数据 按行查看 历史
ToolGood 提交于 2026年01月30日 19:34 +08:00 . fix
import assert from 'assert';
import { AlgorithmEngineHelper } from '../src/AlgorithmEngineHelper.js';
import { CalculateTreeType } from '../src/Enums/CalculateTreeType.js';
/**
* 计算树测试
*/
export class CalculateTreeTest {
static Test1() {
console.log('开始测试 CalculateTreeTest.Test1');
let txt = "A1+1";
let t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Add, `Expected Add, got ${t1.Type}`);
assert.strictEqual(txt.substring(t1.start, t1.end + 1), "A1+1", `Expected "A1+1", got "${txt.substring(t1.start, t1.end + 1)}"`);
assert.strictEqual(t1.conditionString, "A1+1", `Expected "A1+1", got "${t1.conditionString}"`);
txt = "A1-(1+1)";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Sub, `Expected Sub, got ${t1.Type}`);
assert.strictEqual(t1.nodes[1].conditionString, "1+1", `Expected "1+1", got "${t1.nodes[1].conditionString}"`);
txt = "A1*(1+1)";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Mul, `Expected Mul, got ${t1.Type}`);
txt = "A1/(1+1)";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Div, `Expected Div, got ${t1.Type}`);
txt = "A1%(1+1)";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Mod, `Expected Mod, got ${t1.Type}`);
txt = "A1&(1+1)";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Connect, `Expected Connect, got ${t1.Type}`);
txt = "A1(1+1)";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.String, `Expected String, got ${t1.Type}`);
txt = "A1(1+1)-";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Error, `Expected Error, got ${t1.Type}`);
txt = "-1+(1+1)";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.Add, `Expected Add, got ${t1.Type}`);
txt = "-1";
t1 = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(t1.Type, CalculateTreeType.String, `Expected String, got ${t1.Type}`);
console.log('CalculateTreeTest.Test1 测试通过');
}
static TestError() {
console.log('开始测试 CalculateTreeTest.TestError');
let txt = "";
let tree = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(tree.Type, CalculateTreeType.Error, `Expected Error, got ${tree.Type}`);
assert.strictEqual(tree.ErrorMessage, "exp is null", `Expected "exp is null", got "${tree.ErrorMessage}"`);
console.log('CalculateTreeTest.TestError 测试通过');
}
static TestComplexExpressions() {
console.log('开始测试 CalculateTreeTest.TestComplexExpressions');
let txt = "A1+B1*C1";
let tree = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(tree.Type, CalculateTreeType.Add, `Expected Add, got ${tree.Type}`);
txt = "A1*(B1+C1)/D1";
tree = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(tree.Type, CalculateTreeType.Div, `Expected Div, got ${tree.Type}`);
txt = "A1+B1-C1*D1/E1";
tree = AlgorithmEngineHelper.ParseCalculate(txt);
assert.strictEqual(tree.Type, CalculateTreeType.Sub, `Expected Sub, got ${tree.Type}`);
console.log('CalculateTreeTest.TestComplexExpressions 测试通过');
}
static RunAllTests() {
console.log('开始运行所有 CalculateTree 测试');
this.Test1();
this.TestError();
this.TestComplexExpressions();
console.log('所有 CalculateTree 测试运行完成');
}
}
// 浏览器支持
if (typeof window !== 'undefined') {
window.CalculateTreeTest = CalculateTreeTest;
}
// 执行测试
CalculateTreeTest.RunAllTests();
Loading...
举报
举报成功
我们将于2个工作日内通过站内信反馈结果给你!
请认真填写举报原因,尽可能描述详细。
请选择举报类型
取消
发送
误判申诉

此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。

如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。

取消
提交

简介

ToolGood.Algorithm是一个功能强大、轻量级、兼容Excel公式的算法类库,旨在提高开发人员在不同业务场景中的生产力。
暂无标签
未知许可证
查看未知开源许可协议
取消

发行版

暂无发行版

贡献者

全部

近期动态

不能加载更多了
编辑仓库简介
简介内容
主页
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C#
1
https://gitee.com/toolgood/ToolGood.Algorithm.git
git@gitee.com:toolgood/ToolGood.Algorithm.git
toolgood
ToolGood.Algorithm
ToolGood.Algorithm
master
点此查找更多帮助

搜索帮助

评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册

AltStyle によって変換されたページ (->オリジナル) /