批处理之家's Archiver

老刘1号 发表于 2017-3-23 12:23

[20171031更新]一行VBS代码构造强力计算器!

[i=s] 本帖最后由 老刘1号 于 2017-11-1 12:37 编辑 [/i]

[size=4][color=Red]老刘原创,如有雷同,纯属巧合[/color][/size][code]EXECUTE "MSGBOX ""结果:"" & "&INPUTBOX("输入算式:")[/code][code]MsgBox "结果:" & Eval(InputBox("输入算式:"))[/code][size=6][color=Lime]2017-10-31补充了各种函数及其返回值,基本照抄微软参考文档[/color][/size]
[quote]角度转弧度:
弧度=(Pi/180)*角度[/quote]
可用函数:
Abs(number) '绝对值
Sgn(number)
如果 number 为|Sgn 返回
大于零              |1
等于零              |0
小于零              |-1
Sin(number) '正弦(弧度)
Cos(number)'余切(弧度)
Tan(number)'正切(弧度)
Atn(number) '反正切
[quote]利用 Atn 来计算 pi 的值:
Dim pi
pi = 4 * Atn(1)   ' 计算 pi 的值。
[/quote]
Sqr(number) ‘返回平方根
Log(Number) '返回数值的自然对数(e)。
Exp(number) '返回 e(自然对数的底)的幂次方。

[quote]函数 派生的等效公式
Secant(正割) Sec(X) = 1 / Cos(X)
Cosecant(余割) Cosec(X) = 1 / Sin(X)
Cotangent(余切) Cotan(X) = 1 / Tan(X)
Inverse Sine(反正弦) Arcsin(X) = Atn(X / Sqr(-X * X + 1))
Inverse Cosine(反余弦) Arccos(X) = Atn(-X / Sqr(-X * X + 1)) + 2 * Atn(1)
Inverse Secant(反正割) Arcsec(X) = Atn(X / Sqr(X * X - 1)) + Sgn((X) -1) * (2 * Atn(1))
Inverse Cosecant(反余割) Arccosec(X) = Atn(X / Sqr(X * X - 1)) + (Sgn(X) - 1) * (2 * Atn(1))
Inverse Cotangent(反余切) Arccotan(X) = Atn(X) + 2 * Atn(1)
Hyperbolic Sine(双曲正弦) HSin(X) = (Exp(X) - Exp(-X)) / 2  
Hyperbolic Cosine(双曲余弦) HCos(X) = (Exp(X) + Exp(-X)) / 2
Hyperbolic Tangent(双曲正切) HTan(X) = (Exp(X) - Exp(-X)) / (Exp(X) + Exp(-X))
Hyperbolic Secant(双曲正割) HSec(X) = 2 / (Exp(X) + Exp(-X))
Hyperbolic Cosecant(双曲余割) HCosec(X) = 2 / (Exp(X) - Exp(-X))
Hyperbolic Cotangent(双曲余切) HCotan(X) = (Exp(X) + Exp(-X)) / (Exp(X) - Exp(-X))
Inverse Hyperbolic Sine(反双曲正弦) HArcsin(X) = Log(X + Sqr(X * X + 1))
Inverse Hyperbolic Cosine(反双曲余弦) HArccos(X) = Log(X + Sqr(X * X - 1))
Inverse Hyperbolic Tangent(反双曲正切) HArctan(X) = Log((1 + X) / (1 - X)) / 2
Inverse Hyperbolic Secant(反双曲正割) HArcsec(X) = Log((Sqr(-X * X + 1) + 1) / X)
Inverse Hyperbolic Cosecant(反双曲余割) HArccosec(X) = Log((Sgn(X) * Sqr(X * X + 1) +1) / X)
Inverse Hyperbolic Cotangent(反双曲余切) HArccotan(X) = Log((X + 1) / (X - 1)) / 2
以 N 为底的对数 LogN(X) = Log(X) / Log(N)
[/quote]

610100 发表于 2017-3-24 01:39

厉害。谢谢分享!

Nsqs 发表于 2017-3-24 08:17

[code]a=inputbox("输入:")
execute "a="&a
msgbox a[/code]更直观点

老刘1号 发表于 2017-3-24 12:08

[b]回复 [url=http://www.bathome.net/redirect.php?goto=findpost&pid=197478&ptid=43595]3#[/url] [i]Nsqs[/i] [/b]


    嗯,多费一个变量,不过可读性高了

老刘1号 发表于 2017-3-24 12:20

[i=s] 本帖最后由 老刘1号 于 2017-7-27 09:20 编辑 [/i]

再附一个批处理调用版(灵感来自于PCL斑竹的一段代码):
放到批处理文件末尾即可。[code]
GOTO :EOF
:CALC
for /f %%a in ('mshta VBScript:Execute("CreateObject(""Scripting.Filesystemobject"").GetStandardStream(1).Write(%~1)"^)(close^)') do Echo.%%a
[/code]用法:[code]Call :Calc 1+1-1+666-999 %计算前面一堆的结果%
Call :Calc 2^^10 %计算2的10次方%
Call :Calc 1024^^0.1 %计算1024的0.1次方%
Call :Calc 1.665544332211111111111111111123-0.55443322110000000000000012 %计算浮点数加减%
Call :Calc (9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9*9.9)^^(1/15) %计算浮点数相乘除,幂运算%
[/code]返回可以用FOR收集

wskwfkbdn 发表于 2017-3-24 12:39

[b]回复 [url=http://bbs.bathome.net/redirect.php?goto=findpost&pid=197451&ptid=43595]1#[/url] [i]老刘1号[/i] [/b]


    顶老刘 赞老刘

523066680 发表于 2017-3-24 12:49

很久以前,用的 eval,结合 cscript 放在终端环境里。[code]set inp=wscript.stdin
set put=wscript.stdout

put.writeline "input exit to exit"
while true
        put.write "Test:"
        yousay = inp.readline

        if yousay="exit" then
                wscript.quit
        end if

        x=eval(yousay)
        put.writeline "x=" & x
wend[/code]eval.bat
cscript //nologo "%~dp0eval.vbs"

计算公式后用 x 指代上一次的结果。

后来发现 python 交互挺好,没怎么用了。

0000 发表于 2017-7-26 19:44

一旦算式里有什么问题或者...

a2002 发表于 2017-7-26 20:02

[b]回复 [url=http://www.bathome.net/redirect.php?goto=findpost&pid=201603&ptid=43595]8#[/url] [i]0000[/i] [/b]


    这只是一行代码,不需要钻牛角尖

a2002 发表于 2017-7-26 20:17

不过这个三角函数计算的是弧度而不是角度...

老刘1号 发表于 2017-7-26 23:27

[i=s] 本帖最后由 老刘1号 于 2017-7-26 23:29 编辑 [/i]

[b]回复 [url=http://www.bathome.net/redirect.php?goto=findpost&pid=201605&ptid=43595]10#[/url] [i]a2002[/i] [/b]


    确实是弧度
补充:
[quote]角度转弧度:
弧度=(Pi/180)*角度
Pi≈3.1415926535898[/quote]

a2002 发表于 2017-7-26 23:42

技术超限了,回头顶你

页: [1]

Powered by Discuz! Archiver 7.2  © 2001-2009 Comsenz Inc.