使用openpyxl Tokenizer解析Excel IF语句

时间:2018-07-25 21:34:59

标签: python python-3.x excel-formula tokenize openpyxl

我发现了this doc on Tokenizer,但是它没有说明如何使用公式并实际执行它(没有该公式似乎毫无用处)。

我需要处理一些简单的IF情况:

formula = '''IF(size<80000,size/80000*(1.85-1.65)+1.65,IF(size<160000
    (size-80000)/80000*(1.65-1.45)+1.45,IF(size<280000,(size-160000)/
    120000*(1.45-1.05)+1.05,IF(size<800000,(size-280000)/520000*(1.05-0.7)+0.7,0))))'''

from openpyxl.formula import Tokenizer
tok = Tokenizer(formula)

我可以看到tok的方法:

print([d for d in dir(tok) if '__' not in d])
['ERROR_CODES', 'SN_RE', 'STRING_REGEXES', 'TOKEN_ENDERS', 'WSPACE_RE', '_parse', '_parse_brackets', '_parse_closer', '_parse_error', '_parse_opener', '_parse_operator', '_parse_separator', '_parse_string', '_parse_whitespace', 'assert_empty_token', 'check_scientific_notation', 'formula', 'items', 'offset', 'render', 'save_token', 'token', 'token_stack']

如果我想将size=100传递到此tok实例并执行它以获取返回的结果,我该怎么做?

有一种很明显的方法,可以使用已解析的标记构建AST,但我很好奇是否可以将公式写入内存中的Excel文档并以这种方式执行函数(如果这样更容易)。我没有为此的Excel文档。我只是有很多公式字符串。

1 个答案:

答案 0 :(得分:0)

openpyxl从不评估公式。标记生成器仅用于解包和重新分配共享公式。确实存在用于评估公式的其他库,但是通常最好将文件传递给MS Excel或OpenOffice或LibreOffice等应用程序进行评估,因为这些库包含用于计算的优化,包括并行化。