使用正则表达式将excel公式转换为wolfram mathematica

前端之家收集整理的这篇文章主要介绍了使用正则表达式将excel公式转换为wolfram mathematica前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_404_3@
我正在导入Excel文件提取这些文件中的公式,以便使用Excel无法执行的各种测试和计算.但是,要做到这一点,我需要将Excels函数转换为Mathematica可以使用的函数.所有这些公式都非常大(平均200页),因此手动转换不是一种选择.这让我想到了当前的问题.
我需要转换的一些公式在Excel函数中包含括号,导致这样的情况:

IF(IF((A2+B2)*(C1+2^D1)<>7,"A","B")="A",C8,D8)*2/IF(G17*G2=G1,IF(EXP(K9)=K10,K11,K12))*EXP(IF(H22+H23=213,A1,B1))

在这里,我需要将IF和EXP函数中的所有()转换为[],而不更改像(A2 B2)那样的部分.
目标是将其转换为:

IF[IF[(A2+B2)*(C1+2^D1)<>7,"B"]="A",D8]*2/IF[G17*G2=G1,IF[EXP[K9]=K10,K12]]*EXP[IF[(H22+H23)=213,B1]]

有没有可以匹配这些情况的正则表达式?

解决方法

string = "IF(IF((A2+B2)*(C1+2^D1)<>7,\"A\",\"B\")=\"A\",D8)*2/IF(\
G17*G2=G1,B1))"

那这个呢:

ClearAll@rectBrackets;

rectBrackets := StringReplace[ #,(f_?UpperCaseQ ~~ fr : LetterCharacter ..) ~~ 
    "(" ~~ Shortest[content__] ~~ ")" /; (
        StringCount[content,")"] == StringCount[content,"("]
    ) :> (
        f <> ToLowerCase[fr] <> "[" <> rectBrackets @ content <> "]"
    )
] &;

operators = StringReplace[#,{"=" -> "==","<>" -> "!="}] &;

现在让我们使用它们:

rectBrackets @ operators @ string

06003

ToExpression @ %

enter image description here

@H_404_3@

猜你在找的正则表达式相关文章