[发明专利]基于Python代码重建抽象语法树的方法、电子设备有效
申请号: | 201811637116.0 | 申请日: | 2018-12-29 |
公开(公告)号: | CN109710307B | 公开(公告)日: | 2022-03-11 |
发明(设计)人: | 孙悦;李天驰;赵子亮 | 申请(专利权)人: | 深圳点猫科技有限公司 |
主分类号: | G06F8/75 | 分类号: | G06F8/75 |
代理公司: | 广东良马律师事务所 44395 | 代理人: | 李良 |
地址: | 518000 广东省深圳市粤海*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 python 代码 重建 抽象 语法 方法 电子设备 | ||
1.一种基于Python代码重建抽象语法树的方法,其特征在于,包括步骤:
将Python代码转化为JavaScript的原始抽象语法树;
获取原始抽象语法树的主体结构,根据所述主体结构的类型创建树对象;
根据主体结构的层级对所述树对象进行重组拼接,获得简洁抽象语法树;
所述将Python代码转化为JavaScript的原始抽象语法树的步骤具体包括:
按照语法作用域将Python代码分割成若干段Python子代码;
读取每段Python子代码的内容;
对Python子代码进行解析,生成各段Python子代码的抽象语法树;
其中,读取每段Python子代码的内容的方式为并列方式;
所述对Python子代码进行解析,生成各段Python子代码的抽象语法树的步骤之后包括:
将生成的各段Python子代码的抽象语法树返回给递归的上层;
然后执行块作用域的循环;
最后按照语法作用域的从属关系拼接Python子代码的抽象语法树,得到原始抽象语法树。
2.根据权利要求1所述基于Python代码重建抽象语法树的方法,其特征在于,所述获取原始抽象语法树的主体结构,根据所述主体结构的类型创建树对象的步骤具体包括:
获取原始抽象语法树的主体结构;
判断所述主体结构是否为数组;
若为数组,则获取所述主体结构的子主体结构,根据所述子主体结构的类型创建相应的树对象;若不为数组则根据主体结构的类型创建相应的树对象。
3.根据权利要求2所述基于Python代码重建抽象语法树的方法,其特征在于,创建树对象的步骤具体包括:
根据所述主体结构或子主体结构的类型查找对应的表达式类型;
根据所述表达式类型创建相应的树对象。
4.根据权利要求1所述基于Python代码重建抽象语法树的方法,其特征在于,所述根据主体结构的层级对所述树对象进行重组拼接,获得简洁抽象语法树的步骤具体包括:
按照主体结构的同级或子级的关系将对应的树对象进行结合,得到简洁抽象语法树。
5.根据权利要求4所述基于Python代码重建抽象语法树的方法,其特征在于,当主体结构中包含子主体结构时,则将所述子主体结构对应的树对象递归至上层。
6.根据权利要求1所述基于Python代码重建抽象语法树的方法,其特征在于,所述根据主体结构的层级对所述树对象进行重组拼接,获得简洁抽象语法树的步骤之后包括:
根据所述简洁抽象语法树调用接口,绘制相应的积木。
7.根据权利要求5所述基于Python代码重建抽象语法树的方法,其特征在于,当递归时,读取主体结构的层级信息,按照层级信息进行递归。
8.根据权利要求1所述基于Python代码重建抽象语法树的方法,其特征在于,根据语法关键字对Python子代码进行解析,生成各段Python子代码的抽象语法树。
9.根据权利要求2所述基于Python代码重建抽象语法树的方法,其特征在于,所述主体结构的类型包括:调用表达式、循环结构或返回结构的一种或几种。
10.根据权利要求6所述基于Python代码重建抽象语法树的方法,其特征在于,所述根据所述简洁抽象语法树调用接口,绘制相应的积木的步骤具体包括:
创建一画布,并在所述画布中绘制相应的积木。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于深圳点猫科技有限公司,未经深圳点猫科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811637116.0/1.html,转载请声明来源钻瓜专利网。