Python Formulas模型以JSON格式文件导出导入

1. 导入formulasjson

在加载模型之前,导入formulasjson包。

bash 复制代码
import formulas, json

2. 加载Excel模型

加载一个公式复杂的Excel模型,该模型耗时较长,我们可以观察使用json格式是否能更高效。

python 复制代码
xl_model = formulas.ExcelModel().load('./workbook.xlsx').finish()

3. 导出为JSON文件

将模型转化为可JSON化的字典(dict)类,然后通过json.dumps输出到json文件中。

python 复制代码
xl_dict = xl_model.to_dict()  # To JSON-able dict.

with open('./xl_model.json', 'w', encoding='utf-8') as model_out:
    json.dump(xl_dict, model_out, ensure_ascii=False, indent=True) # to JSON, and save it to a file.

4. 导入JSON文件

读取JSON格式Excel模型文件,并以字典(dict)方式加载模型。事实上效果和直接加载Excel是一样的,耗时也差不多。

python 复制代码
data = {}
with open('./xl_model.json', 'r', encoding='utf-8') as model_in:
    data = json.load(model_in)
loaded_model = formulas.ExcelModel().from_dict(data)  # From JSON.    

5. 计算示例

python 复制代码
# model calculation
cal_res = loaded_model.calculate(
    inputs={
        "'[workbook.xlsx]管道计算 (混凝土管道简化指标)'!B3": 280
    },
    outputs=[
        "'[workbook.xlsx]管道计算 (混凝土管道简化指标)'!AJ3"
    ]
)
print(cal_res["'[workbook.xlsx]管道计算 (混凝土管道简化指标)'!AJ3"].value[0, 0])

计算结果:771.4635658334801

python 复制代码
cal_res = loaded_model.calculate()
print(cal_res["'[workbook.xlsx]管道计算 (混凝土管道简化指标)'!AJ3"].value[0, 0])

计算结果:792.8609135167501

相关推荐
cm6543207 分钟前
用Python破解简单的替换密码
jvm·数据库·python
cj814015 分钟前
Prompt,Agent,Skill,Mcp分别于langchain有什么关系
前端
wan9yu23 分钟前
为什么你需要给 LLM 的数据"加密"而不是"脱敏"?我写了一个开源工具
python
SuperEugene29 分钟前
Axios + Vue 错误处理规范:中后台项目实战,统一捕获系统 / 业务 / 接口异常|API 与异步请求规范篇
前端·javascript·vue.js·前端框架·axios
行走的陀螺仪29 分钟前
手写 Vue3 极简 i18n
前端·javascript·vue.js·国际化·i18n
摇滚侠32 分钟前
你是一名 java 程序员,总结定义数组的方式
java·开发语言·python
羽沢3138 分钟前
一篇简单的STOMP教程QAQ
前端·javascript·stomp
code_Bo38 分钟前
使用AI完成Swagger接口类型在前端自动生成的工具
前端·后端·架构
莫爷1 小时前
JSON 性能优化实战:大数据量 JSON 的处理技巧
性能优化·json·apache
这个名有人用不1 小时前
解决 uv 虚拟环境使用 pip 命令提示command not found的办法
python·pip·uv·claude code