gpt4 book ai didi

python - 使用 openpyxl Tokenizer 解析 Excel IF 语句

转载 作者:太空宇宙 更新时间:2023-11-04 04:36:41 25 4
gpt4 key购买 nike

我找到了 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 文档。我只有很多公式字符串。

最佳答案

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

关于python - 使用 openpyxl Tokenizer 解析 Excel IF 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51528009/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com