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

相关推荐
晴殇i1 分钟前
代码隔离革命:用 JavaScript Realm 安全运行不可信代码
前端·javascript
Mr.Jessy6 分钟前
Web APIs 学习第六天:BOM、location对象与本地存储
开发语言·前端·javascript·学习·web api·bom
百***926522 分钟前
Node.js npm 安装过程中 EBUSY 错误的分析与解决方案
前端·npm·node.js
程序员小寒33 分钟前
前端高频面试题之Vue(高级篇)
前端·javascript·vue.js
m0_639817151 小时前
基于springboot纺织品企业财务管理系统【带源码和文档】
java·服务器·前端
石小石Orz1 小时前
qinkun的缓存机制也有弊端,建议官方个参数控制
前端
爱打球的白师傅1 小时前
python机器学习工程化demo(包含训练模型,预测数据,模型列表,模型详情,删除模型)支持线性回归、逻辑回归、决策树、SVC、随机森林等模型
人工智能·python·深度学习·机器学习·flask·逻辑回归·线性回归
用户4099322502121 小时前
Vue浅响应式如何解决深层响应式的性能问题?适用场景有哪些?
前端·ai编程·trae
CC码码1 小时前
重生之我在浏览器里“蹦迪”
前端·javascript·three.js
阡陌昏晨1 小时前
H5性能优化-打开效率提升了62%
前端·javascript·vue.js