iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python的简单四则运算语法树可视化怎么实现
  • 510
分享到

python的简单四则运算语法树可视化怎么实现

2023-07-05 21:07:29 510人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

本文小编为大家详细介绍“python的简单四则运算语法树可视化怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python的简单四则运算语法树可视化怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。简

本文小编为大家详细介绍“python的简单四则运算语法树可视化怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python的简单四则运算语法树可视化怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

简单四则运算语法树可视化

如果想要动手尝试一下,需要安装一下这个 python 可视化库。

python的简单四则运算语法树可视化怎么实现

解析 AST

Python 的 ast 库有一个 parse 方法,可以把传入的内容,解析成一个 AST。然后我们使用 ast.dump 将其导出并打印。
注意:indent 这个参数是 Python 3.9 以后才有的,如果版本低的话,可以去掉,只会影响最后输出的格式。

python的简单四则运算语法树可视化怎么实现

好了,就是这么简单。我们已经做到了,因为这个库的功能很强大,但是这里只是用到一点点而已。其实这里已经可以看出基本的结构了,不过我的目的是生成这棵树的 JSON 表示。我想要使用上面的 Python 绘图库把它绘制出来,它所支持的输入是 jsON,并且它的格式为:

{"name": "A","children": ["name": "B","children": []]}

粗糙的遍历方法

"""Python's AST利用 Python 的 ast 模块来解析表达式(简单的二元运算),然后通过遍历语法树来生成 JSON 表示,再使用 PYthon 的库来将其可视化。这个程序的目的是为了验证自己写的简易解析器是否正确。"""import astimport json# 操作类型和操作符映射的字典OPERATORS = {    ast.Add: "+",    ast.Sub: "-",    ast.Mult: "*",    ast.Div: "/"}def generate(tree: ast.Module):    """    generate expression AST's representation of JSON    """    if not tree:        raise Exception("Emtpy AST tree!")    if tree.__class__ == ast.Module:        print(json.dumps({            "name": "Expr",            "children": [DFS(tree.body[0].value)]  # type: ignore        }, indent=4))def DFS(node):    """    DFS AST    """    if not node:        return {}    if node.__class__ == ast.BinOp:        return {            "name": "BinOp",            "children": [                {                    "name": "left",                    "children": [                        DFS(node.left)                    ]                },                DFS(node.op),                {                    "name": "left",                    "children": [                        DFS(node.right)                    ]                }            ]        }    if node.__class__ == ast.Constant:        return {            "name": "NUMBER",            "children": [                {                    "name": str(node.value)  # Python 的绘图库,必须是字符串才能正常显示                }            ]        }    if node.__class__ in [ast.Add, ast.Sub, ast.Mult, ast.Div]:        return {            "name": "Op",            "children": [                {                    "name": OPERATORS[node.__class__]                }            ]        }    # 这里我只处理 加减乘除和数字类型的运行    raise Exception("There is not support extra type.")if __name__ == "__main__":    ast_tree = ast.parse("1+2+3+4+5")    print(ast.dump(ast_tree, indent=4))    generate(ast_tree)

运行结果:
我这里会输出两个东西,一个是 AST 的 dump;另一个是 AST 的 JSON 表示(逻辑结构的 JSON 表示,不是对象的 JSON 表示)。

python的简单四则运算语法树可视化怎么实现

渲染显示

把打印出来的 JSON 字符串复制进文件,命名为 data.json。我感觉直接输出到控制台蛮有意思的,我喜欢直接看到它的结果。
执行如下命令:pytm-cli -d TB -i data.json -o demo.html
在浏览器打开 demo.html 即可看到效果了。

python的简单四则运算语法树可视化怎么实现

主流的遍历方法

上面这种遍历方法虽然便于理解,但是难以扩展。AST 通常是通过 访问者模式 进行遍历的,而且 ast 库也提供了几种遍历方法。
因为这里只需要遍历来生成 JSON,并不需要修改AST本身,所以我们只看下面这两种即可。显然第一种是不能用的,原因已经用蓝色标记出来了。它自己说了如果你不关心上下文,因为生成 JSON 实际上是需要关注这个的。所以,我选择下面的 ast.NodeVisitor。使用它也很简单,继承这个类,然后对不同的节点写不同的处理逻辑就行了(这样把不同节点的逻辑分开了,降低了代码的耦合性)。

python的简单四则运算语法树可视化怎么实现

完整代码

"""Python's AST利用 Python 的 ast 模块来解析表达式(简单的二元运算),然后通过遍历语法树来生成 JSON 表示,再使用 PYthon 的库来将其可视化。这个程序的目的是为了验证自己写的简易解析器是否正确。"""import astimport json# 操作类型和操作符映射的字典OPERATORS = {    ast.Add: "+",    ast.Sub: "-",    ast.Mult: "*",    ast.Div: "/"}class JSONVisitor(ast.NodeVisitor):    """    JSON visitor: Traversal AST and generate JSON representation    """    def visit_Module(self, node):        module = {            "name": "Module",            "children": []        }        for sub_node in node.body:            module["children"].append(self.visit(sub_node))        return module    def visit_Expr(self, node):        return {            "name": "Expr",            "children": [                self.visit(node.value)            ]        }    def visit_BinOp(self, node):        return {            "name": "BinOp",            "children": [                {                    "name": "left",                    "children": [                        self.visit(node.left)                    ]                },                self.visit(node.op),                {                    "name": "right",                    "children": [                        self.visit(node.right)                    ]                }            ]        }    def visit_Constant(self, node):        return {            "name": "NUMBER",            "children": [{                "name": str(node.value)  # # Python 的绘图库,必须是字符串才能正常显示            }]        }    def visit_Add(self, node):        return self.__visit(node)    def visit_Sub(self, node):        return self.__visit(node)    def visit_Mult(self, node):        return self.__visit(node)    def visit_Div(self, node):        return self.__visit(node)    def __visit(self, node):        return {            "name": "Op",            "children": [{                "name": OPERATORS[node.__class__]            }]        }if __name__ == "__main__":    ast_tree = ast.parse("1+2+3+4+5")    visitor = JSONVisitor()    json_str = visitor.visit(ast_tree)    print(json.dumps(json_str, indent=4))

前面那个粗糙版本是直接从 Expr 开始的,这个优雅点的版本,我就把 Module 节点也添加进去了。

python的简单四则运算语法树可视化怎么实现

读到这里,这篇“python的简单四则运算语法树可视化怎么实现”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网Python频道。

--结束END--

本文标题: python的简单四则运算语法树可视化怎么实现

本文链接: https://www.lsjlt.com/news/355634.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python的简单四则运算语法树可视化怎么实现
    本文小编为大家详细介绍“python的简单四则运算语法树可视化怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“python的简单四则运算语法树可视化怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。简...
    99+
    2023-07-05
  • python的简单四则运算语法树可视化
    目录简单四则运算语法树可视化解析 AST粗糙的遍历方法渲染显示主流的遍历方法完整代码说明简单四则运算语法树可视化 前几天有一篇博客是关于四则运算和二叉树的,我是把四则运算用二叉树写出...
    99+
    2023-05-14
    python四则运算 python四则运算语法树 python语法树可视化
  • Python实现简单的四则运算计算器
    一、算法 1、算法的主要思想就是将一个中缀表达式(Infix expression)转换成便于处理的后缀表达式(Postfix expression),然后借助于栈这个简单的数据结构,计算出表达式...
    99+
    2022-06-04
    计算器 简单 Python
  • 用Python代码实现5种最好的、简单的数据可视化分别是怎样的
    这篇文章给大家介绍用Python代码实现5种最好的、简单的数据可视化分别是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。数据可视化是数据科学家工作的重要组成部分。在项目的早期阶段,您通常会进行探索性数据分析(ED...
    99+
    2023-06-02
  • 怎么用Python代码实现一个简单的凯撒加密算法
    本篇内容介绍了“怎么用Python代码实现一个简单的凯撒加密算法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作