[AHK]为AutoHotkey打造 表达式求值功能(eval函数)

92 篇文章 3 订阅

 为AutoHotkey打造 表达式求值功能(eval函数),方案很多可以是中缀表达式转后缀表达式、也可以是利用正则表达式处理表达式形式。

本位列举两种方案,方案一:利用Excel的Com对象来辅助计算,好处是支持%  自动忽略空格  还支持excel的内置函数,比如sum这类函数。

方案二:利用VBScript的Com对象来辅助计算,简洁明了,不过不支持% ,也能自动忽略空格,不支持英文函数。


;用excel当计算器 支持% 空格 
;作者: David 尹(153671978)  
oExcel := ComObjCreate("Excel.Application")  
oExcel.Workbooks.Add 
MsgBox % oExcalc("(1     + 4%)*100 ")
MsgBox % oExcalc("(1     + 12^2  )*100 /3400")
MsgBox % oExcalc("sum(1     + 2  +3+4+5+6+7+8+9+10)")
oExcel.DisplayAlerts:= False
oExcel.Quit
return

 oExcalc(string,format="")
 {
     global oExcel
     try{
        oExcel.Range("A1").Formula := "= " . string
     }
    return % oExcel.Range("A1").Value
 }




;这个借用Vbs也可以,不过不支持百分号。
eval(str)
{
    spt := ComObjCreate("ScriptControl")
    spt.Language := "VBScript"
    Return,% spt.Eval(str)
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值