如何自定义python语法.
我们需要准备vs,msys2,gcc
等材料.
然后要改.从最简单的开始,先将def加一个df
来定义.
我们的流程是:
1,先在msys2
里面执行./configure
,然后在生成的makefile
里面如下修改,先配置一次
,可能修改语法后,还要再运行
:
OPT= -DNDEBUG -g -fwrapv -O3 -Wall -fexec-charset=gbk -finput-charset=gbk
BASECFLAGS= -Wno-unused-result -Wsign-compare -fexec-charset=gbk -finput-charset=gbk
加上gbk
编码,非常重要,不然regen-all
编译不过.
2,修改你要改的语法.如
function_def_raw[stmt_ty]:
| ('def'|'df') n=NAME '(' params=[params] ')' a=['->' z=expression { z }] ':' tc=[func_type_comment] b=block {
3,msys2
里面make regen-all
,然后生成.
4,在pcbuild
里面点进一个目录,然后再F7
全部生成.
这里面最重要的就是英文
原有关键字,不要删.因为库代码就是用的这个
,所以你删了,绝对一大堆错误
,还编译不过.因为有个_freeze_importlib.exe
就是用的最新的语法(这个还是刚刚生成的新鲜的,所以,你老是通不过,通不过
).你删了原有的东西,完了,编译不过,编译不过
.
5,然后就是几个要改的地方:
.\Modules\clinic\_pickle.c.h
.\Modules\clinic\_statisticsmodule.c.h
.\Modules\_pickle.c
.\Modules\_statisticsmodule.c
.\Parser\pgen\pgen.py
.\Tools\clinic\clinic.py
.\Tools\peg_generator\pegen\build.py
.\Tools\peg_generator\pegen\c_generator.py
.\Tools\scripts\update_file.py
主要是把with open
的打开方式,改为encoding='gbk',errors='ignore'
,不然有问题,编译不了.
为什么要在msys2
里面改,因为必须要用make regen-all
和配置
来重新修改有些解析文件
.然后python.sln
再利用这些文件来生成python
.
搞不定py
的中文化
.下面是备注:
make regen-grammer,
make regen-all
先生成语法,.生成的graminit.c
要转成gbk,再生成所有.主要是生成parser.c
执行上一步,然后就用微软的来编译
regen-all
里面的regen-grammer
未弄起,即先做了一下,然后注释掉了.因为graminit.c
要转成gbk
.
将生成的lib.keyword
,也要转成gbk
以后别人有方法时再来.折腾啊.
可能的参考地址
在parser.c
里面按大小,顺序
排列好关键词
.
然后,在unicodeobject.c
里面,修改默认为gbk
编码.再编译试试.
参考地址
这里
这里
可能得关注这个函数:decode_code_page_stateful
.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现