这两天我想做一个简谱,在网上搜索乐谱排版软件,发现了基于GPL协议的Lilypond软件。只不过Lilypond是用来做五线谱的。幸好,又找到剑桥大学 Silas S. Brown 编写的一个 jianpu-ly.py 脚本,通过调用Lilypond能够最终生成简谱。关于它的详细介绍请看这里

该脚本支持的简谱语法规则如下:

  • 音阶:1 2 3 4 5 6 7 1’
  • 空拍:0
  • 升、降音:#1 b2
  • 低两个八度、低八度、中音、高八度、高两个八度:1,, 1, 1 1’ 1’’
  • 六十四分、三十二分、十六分、八分、四分音符(一拍):h1 d1 s1 q1 1
  • 符点音符:s1. q1. 1.
  • 半音符(两拍):1 -
  • 符点半音符(三拍):1 - -
  • 全音符(四拍):1 - - -
  • 拍子:4/4
  • 大调:1=Bb
  • 小调:6=F#
  • 标题:title=采茶舞曲
  • 三联音:3[ q1 q1 q1 ]
  • 重复:R{ 1 1 1 } A{ 2 | 3 }

同时在原始脚本的基础之上我还作了一些修改,增加了乐曲速度(tempo)设定功能。

一个典型的简谱源文件如下:

%% tempo: 4=60
title=标题
1=C
2/4

1 2 3 4 5 6 7 1'

将该文件存为jianpu.txt后,先调用jianpu-ly.py生成Lilypond输入文件:

jianpu-ly.py < jianpu.txt > jianpu.ly

然后调用lilypond程序,生成指定格式的乐谱文件。令人惊喜的是,不光可以排版出PDF、PS、PNG等格式的简谱,还可以生成midi文件,直接播放试听。可以用如下方式调用lilypond

# 生成PDF文件、midi文件
lilypond jianpu.ly
# 生成png文件、midi文件
lilypond --png jianpu.ly
# 生成ps文件、midi文件
lilypond --ps jianpu.ly

可以用timidity直接播放生成的midi文件,或者将其转换为RIFF wav格式,再用普通的音频播放器来听。

timidity -Ow -o jianpu.wav jianpu.midi

为了方便使用,我编写了一个bash脚本make_jianpu.sh,用于将上述几个命令的执行自动化。

此外,我在使用的过程中发现,若使用默认的Lilypond设置,虽然能够生成正确的midi文件,但却无法排版出升、降与还原号(accidentals)。经过一番试探,发现只要在/usr/share/lilypond/2.14.2/ly/engraver-init.ly文件中第168行添加:

\consists "Accidental_engraver"

便可以解决该问题。这是因为,经jianpu-ly.py脚本转换生成的Lilypond文件基于的是RhythmicStaff context。而engraver-init.ly中的默认配置并未包括对accidentals的“雕刻”(engrave)。所以,需要手动加上。

至此,用于简谱排版的工具已经俱备。我试着编排了《博基上校进行曲》片段如下。大家可以体验一下Lilypond的效果。

源文件:

%% tempo: 4=120

title=博基上校进行曲
arranger=排版:皮波迪先生@豆瓣 2016-02-14
1=C
2/4

q1' q0 q7. s6 q5 q3 q1 q3 q5 s5 s6 q5 s5 s6 5 -

R{ q5 q3 0 q0 q3 q4 q5 3' 3' 1' - q5 q3 0 q0 q3 q4 q3 5 5 4 - q4 q2 0 }

A{ q0 q2 q3 q4 q5 q3 0 q0 q3 q4 q3 q2 5 q3 q#4 2 q6 5 ( - 5 ) - | 
   q0 q6 q7 q6 } q1' q5 0 q0 q5 q4 q3 q2 6 q2 q7, 5 q7, 1 ( - 1 ) q3 q3 1'. q7 s6 s#5 q6 q5 q4 3 ( - q3 ) q3 q4 q3 6 q#5. s6 1' q6. s1' #2' ( - #2' ) 6 3'. q2' s1' s7 q6 q#5. s6 2. q4 q6 q0 s1' s7 s1' s2' q3' q0 q7. s1' 6 ( - 6 ) q3 q3 1'. q7 s6 s#5 q6 q5 q4 3 ( - q3 ) q3 q4 q3 6 q#5. s6 1' q6. s1' #2' ( - #2' ) 6 3'. q2' s1' s7 q6 q#5. s6 2. q4 q6 q0 s1' s7 s1' s2' q3' q0 q7. s1' 6 ( - 6 ) 5 \ff

简谱:

jianpu-ly.pymake_jianpu.sh的源代码可以在这里下载。