通过添加列表操作等功能,已可编写经典排序算法。另外,作为代码编辑器的第一步,用 Python 实现了带基本语法高亮的编辑器原型,用于显示木兰源码。
用 tkinter 的 Text 实现了如下的木兰源码高亮效果:
添加了列表操作、多项赋值等等基本功能,编写经典算法已经可行。比如快速排序:
func 分区(数列, 下界, 上界) {
中值 = 数列[上界] // 中值可以取任意一个位置的
前位 = 下界
for 后位 in 下界..上界 {
if 数列[后位] < 中值 {
数列[前位], 数列[后位] = 数列[后位], 数列[前位]
前位 += 1
}
}
数列[前位], 数列[上界] = 数列[上界], 数列[前位]
return 前位
}
func 快速排序(数列) {
func 递归(各项, 下界, 上界) {
if 下界 < 上界 {
中位 = 分区(各项, 下界, 上界)
递归(各项, 下界, 中位 - 1)
递归(各项, 中位 + 1, 上界)
}
}
递归(数列, 0, len(数列) - 1)
}
支持了三元运算? :
,见例程测试/手工测试/命令行.ul
:
using Cmd in cmd
using 随机范围数 in 随机数
using exit in sys
type 猜数字 : Cmd {
{
intro = "木兰想了个 100 之内的数,猜猜是几?"
想的 = 随机范围数(100)
prompt = '请猜吧: '
}
func $default(行) {
数 = int(行)
if 数 == self.想的 {
println("中了!")
exit()
} else {
println("太" + (数 > self.想的 ? "大" : "小") + "了!")
}
}
}
猜数字().cmdloop()
下面是几个主要部分的代码行数统计,+的为相对上周的增量。
测试.py
,运行测试的脚本:123 + 12test语法树.py
,确保生成的语法树与原始版本一致:52 + 11分析器/语法分析器.py
,包括 AST 转换:569 + 83 = 652分析器/语法树.py
,功用/调试辅助.py
,包括对 ast 库的中文封装:214 + 37词法分析器.py
,主要是词法规则:110 + 13rply_parser.py
,支持空行的权宜之计:117演示高亮.py
:80环境.py
,全局变量:30 + 3添加对木兰模块的支持,改进编辑器。