- +1
Python代码转Latex公式,这个开源库用一行代码帮你搞定
机器之心报道
编辑:小舟
你的代码中有数学公式吗?
数学是数据科学和机器学习的重要基础,数学运算的结果对于机器学习项目而言是至关重要的。在编写代码时,我们常常需要定义数学公式的计算形式。像 S=r^2 这样简单的数学公式,大概不会出现拼写错误。但如果是下面这样的公式呢?

还记得数学老师密密麻麻的板书吗?人们习惯于手写公式的运算过程。而如果计算机编程语言能够显示出类似于手写公式的计算过程,检查公式运算是否准确就可以轻松多了吧。
近日,GitHub 上一个名叫 handcalcs 的开源库就解决了这个问题。
项目地址:https://github.com/connorferster/handcalcs
handcalcs 库:将 Python 计算代码转换为 Latex 公式
handcalcs 库可将 Python 计算代码自动渲染为 Latex 公式,呈现方式类似于手写的公式计算:先编写符号公式,再代入具体数字,最后得出结果。

而人们更习惯的是如下形式的数学公式:

数学计算的结果往往会影响后续代码的运行过程,而复杂的数学公式更容不得一点错漏,因此对于包含较多复杂数学公式的 Python 代码,用 handcalcs 进行自查或许是有必要的。
如何使用 handcalcs?
那么,这个开源库要如何应用呢?
基本用法 1:Jupyter 单元格魔法函数
handcalcs 的设计初衷是在 Jupyter Notebook 或 Jupyter Lab 中作为单元格魔法函数来使用。
首先,引入 handcalcs 模块并运行单元格:
import handcalcs.render
接下来,在想要使用 handcalcs 的单元格上面添加一行魔法函数 %%render:
%%render
例如:
%%rendera = 2b = 3c = 2*a + b/3
如果系统安装了 Latex 环境,你还可以将 notebook 导出成 pdf 格式文件。
基本用法 2:函数装饰器 @handcalc()
除了在 Jupyter cell 中使用外,在 Python 的函数中也可以使用 handcalcs。
首先导入 @handcalc() 装饰器:
from handcalcs.decorator import handcalc
然后编写函数。注意:函数必须 return locals():
@handcalc()def my_calc(x, y, z): a = 2*x / y b = 3*a c = (a + b) / z return locals()
@handcalc(left: str = "", right: str = "", jupyter_display: bool = False)
返回一个由 (latex_code: str, locals: dict) 组成的元组,其中 locals 是函数命名空间范围内所有变量的字典。
其他功能
有些公式的参数量较多,如果按照常规的格式显示在一列,会浪费大量空间。而使用 handcalcs,只需添加注释标签# Parameters 就能让参数以三列的形式显示出来:


有时你并不需要代入数值计算,只需要以符号的形式显示数学计算公式。那么,你需要使用# Symbolic 标签:





虽然用处多多,但项目作者表示,handcalcs 仍存在一些小缺陷。
首先,handcalcs 并不适用于 collections 这种数据类型,例如 list、tuple、dict 等。
其次是在变量名方面,handcalcs 是针对 Jupyter 环境设计的。如果在 notebook 上重复使用变量名,则可能导致错误的数学运算。
handcalcs 虽然有些小瑕疵,但它对开发者而言颇有帮助。感兴趣的话,快来动手试一下吧!
Amazon SageMaker 是一项完全托管的服务,可以帮助开发人员和数据科学家快速构建、训练和部署机器学习 模型。SageMaker完全消除了机器学习过程中每个步骤的繁重工作,让开发高质量模型变得更加轻松。
现在,企业开发者可以免费领取1000元服务抵扣券,轻松上手Amazon SageMaker,快速体验5个人工智能应用实例。
© THE END
转载请联系本公众号获得授权
投稿或寻求报道:content@jiqizhixin.com
原标题:《Python代码转Latex公式,这个开源库用一行代码帮你搞定》
本文为澎湃号作者或机构在澎湃新闻上传并发布,仅代表该作者或机构观点,不代表澎湃新闻的观点或立场,澎湃新闻仅提供信息发布平台。申请澎湃号请用电脑访问http://renzheng.thepaper.cn。





- 报料热线: 021-962866
- 报料邮箱: news@thepaper.cn
互联网新闻信息服务许可证:31120170006
增值电信业务经营许可证:沪B2-2017116
© 2014-2025 上海东方报业有限公司