SciTE的这个功能比我想像的还要强大地多,几乎可以和Zen Coding相媲美了。下面介绍下它的用法,更详细的可以参考《懒人专用--用好SciTE的缩写功能》这篇文章。
首先建立一个缩略词文件,比如想给HTML使用,那么可以建立一个html.properties文件,当然文件名称和后缀可以任意取,只要你看地懂就可以了。为了方便管理,可以在SciTE的目录下建立一个abbrev文件夹,专门用于存放缩略词文件。
在SciTE的头部菜单选项中选择打开 User Options 文件一项,在打开的SciTEUser.properties文件的最底部加上如下代码:
abbreviations.*.html=$(SciteDefaultHome)\abbrev\html.properties
上面代码中,abbreviations.*.html代码表示该缩略词文件只对后綴名为html的文件有效;$(SciteDefaultHome)表示SciTE的安装目录;\abbrev\html.properties表示缩略词文件相对于SciTE安装目录的位置。
SciTE的缩略词规则很简单,就是:
缩略词=完整代码
现在在新建的html.properties文件中写入如下代码:
a=<a href="">|</a>
接下来打开一个后缀名为html的文件,在里面输入a,再按快捷键Ctrl+B,刚才的字母a就被替换成了<a href=”"></a>,而光标会自动定位到代码<a href="">
和</a>
之间,也就是在上面定义的缩略词代码中|所在的位置。
注意事项:
缩略词表达示不允许换行
缩略词表达示不允许换行,因为SciTE是用换行来区分两个缩略词表达式的。如果想完整代码显示换行可以用\n来实现,另外可以用\t来表示缩进。如下面代码:
html:5=<!DOCTYPE HTML>\n<html lang="en-US">\n\t<head>\n\t\t<meta charset="UTF-8">\n\t\t<title></title>\n\t</head>\n\t<body>\n\t\t|\n\t</body>\n</html>
在HTML文件中输入html:5,按Ctrl+B,代码展开后是下面这样的:
<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
</body>
</html>
缩略词表达示不能以#、空格键、tab键开头
缩略词表达示不能以#开头,这样会被当成注释忽略掉。
转义符“\”和“|”
想在完整代码里显示\,可以连续输入两个\。如:
line=\\iloveweb
展开后是\iloveweb
,如果想显示两个\,就连续输入四个\,如下(以“#”开头的一行是注释):
#显示 \iloveweb
line1=\\iloveweb
#显示 \\iloveweb
line2=\\\\iloveweb
显示|的规则也一样,如下:
#显示 \iloveweb
or1=||iloveweb
#显示 ||iloveweb
or2=||||iloveweb
给缩略词取个易记易懂的名字
给缩略词取个易记易懂的名字不难,因为已经有个现成的:Zen Coding,可以参考它的写法来编写SciTE的缩略词。下面列出一部分我参考Zen Coding的代码段:
cc:ie=<!--[if IE]>\n\t|\n<![endif]-->
a=<a href="">|</a>
a:link=<a href="http://|"></a>
a:mail=<a href="mailto:|"></a>
script:cdata=<script type="text/javascript">\n//<![CDATA[\n\n|\n\n//]]>\n</script>
input=<input type="" value="|" />
input:text=<input type="text" name="|" id="" />
SciTE,支持语法高亮、自动补完、函数提示和编译运行等重要功能,甚至还有导出成PDF文档的功能,启动速度却和记事本差不多,当然最重要的原因是支持Python,所以我强烈推荐。
不过这是个面向程序员的编辑器,配置非常复杂,所以一般人就不用尝试了…
先给2张截图,这是我自己配置的代码高亮样式,应该算是清爽的吧:
自动完成和提示也很强大:
接着稍微介绍一下,SciTE是基于SCIntilla的,另几款知名的文本编辑器,如Notepad++、Notepad2、Eric3、Wing IDE和PythonWin也都是基于该库,可见其强大。
它也是跨平台的,可运行于Windows和GTK+ / Linux兼容操作系统下。
下载页面里有多种版本,我下的是Windows平台完整版的(目前是2.01版,883KB)。此外还有UPX压缩的单文件版和安装版。
这是个绿色软件,解压后运行SciTE.exe就可以启动了,不过界面是英文的,而且找不到地方设置。于是去下载语言文件,例如Chinese 1.73 (Simplified - GB2312),再重命名为locale.properties,保存到SciTE文件夹下,重启编辑器即可。
不过很快你会发现中文支持很烂,移动光标和选择文字会截断中文,实在让中文用户很头疼。这实际上是代码页的设置问题,需要手动更改配置文件。
SciTE中最重要的配置文件就是SciTEGlobal.properties了,你可以通过“选项—打开Global Options文件”来打开。
搜索code.page,很快就发现它被设为0了,也就是自动。
在它下面写上code.page=936,就可以覆盖上面的设置,设为GBK了。此外,#表示行注释,所以你也可以注释掉这行。这时就能正常支持中文了。而输出是用output.code.page=936,但一般不会出错。如果字体不正常,可以加上character.set=132试试。另外,繁体中文是950/136,日文是932/128,韩文是949/129。
不过保存文件时仍然会发现,无法保存成UTF-8格式。实际上在“文件—编码”里有编码设置,保存时会自动转换成该编码。所以只要在这改成UTF-8,就会自动保存成UTF-8格式了。
此外,打开文件时,SciTE会检查BOM来判断是否是UTF-8或UCS2编码。而如果文件头2行有# -*- coding: utf-8 -*-或<?xml versinotallow='1.0' encoding='utf-8'?>,也会当成UTF-8来解码。
设置完语言后,就不妨读读SciTE文档,看看有些什么功能吧。
一开始就能看见,它能当成IDE来使用。如果安装了Python的话,写个Python文件,保存,然后按F5,就会运行了。这个快捷键和VC等IDE是一样的,多用几次就记住了;另外,切换输出窗口可用F8。
不过我在使用中发现一个问题,如果print包含非ASCII字符的unicode的话,会报UnicodeEncodeError。目前的解决办法是不使用unicode,直接使用字符串…
接着可以看到它还支持命令行参数,例如-goto:123可以跳到123行,不过一般人都习惯鼠标双击打开吧…
接下来是缓冲区,它实际上就是打开的文件,可以用F6和Shift+F6进行切换,默认可以打开10个。
然后是会话,它用于保存当前打开的文件(缓冲区)状态。可以在配置文件中设置save.sessinotallow=1来启用,就相当于启动时自动载入上一次操作的文件。而save.positinotallow=1可以保存光标位置。
搜索也是支持正则表达式的,此外还有个很酷的“即输即查”功能,用过Chrome、iTunes和苹果操作系统的应该很熟悉。搜索窗口在查询后就会关闭,可以用F3和Shift+F3来进行下一次搜索。
接着是一些快捷键,稍微写些常用的:
Tab / Shift+Tab:切换缩进
Ctrl+BackSpace / Ctrl+Delete:删除单词
Ctrl+Shift+BackSpace / Ctrl+Shift+Delete:删除行
Ctrl+Home / Ctrl+End:跳转到文件头/尾
Alt+Home / Alt+End:跳转到显示行头/尾(自动换行也会产生新的显示行)
Ctrl+L:剪切行
Ctrl+Shift+T:复制行
Ctrl+Shift+L:删除行
Ctrl+T:与前一行交换
Ctrl+D:重复选择区域或当前行
Ctrl+[/ Ctrl+]:跳转到上/下一段
Ctrl+Left / Ctrl+Right:跳转到上/下一个词
Alt+Shift+上下左右:选择一块文本(还可以按住Alt,用鼠标选择)
此外还有代码折叠。按住Ctrl再点折叠处会折叠/展开所有子结点,而按住Ctrl+Shift再点折叠处可以折叠/展开所有结点。这个功能对HTML/XML也有效,感觉很方便。
再来看看配置文件,由于太多了,只挑一些常用的:
position是位置配置,其中position.maximize=1可以启动时最大化。
blank.margin.left用于控制左边距,可以设为负值来减少折叠区宽度。
line.margin.visible=1可以默认显示行号
minimize.to.tray=1设置最小化到托盘区。
toolbar.visible=1可以显示工具栏,但我是不让它显示的,基本上都用快捷键和菜单。
statusbar.visible=1可以显示状态栏,这个很有必要。statusbar.number是设置状态的种数的,如果有多种,鼠标点击时就会循环切换。statusbar.text.number,这个用于设置每种状态显示的信息,默认显示状态1。
check.if.already.open=1可以检查是否被已其他程序打开该文件。
autocompleteword.automatic=1是个很重要的选项,它会检查文件中所有存在的单词,但再次输入时,会时时提示可能的单词进行补完。
user.shortcuts和user.context.menu可以设置自己的快捷键和右键菜单,这里有命令列表。
wrap=1和output.wrap=1可以自动换行,不设置的话会有很长一条滚动条。不过horizontal.scroll.width和output.horizontal.scroll.width可以设置滚动条宽度
find.files可以设置文件搜索时的默认后缀名,我当然设成*.py。
font可以进行一些字体设置,其中font.monospace是等宽字体,也是编程中最常用的字体。不过我没找到默认开启等宽的方法,只好设置这2个:font.base=$(font.monospace)和font.comment=$(font.monospace);或者style.*.32=$(font.monospace)。不过按Ctrl+F11也很快。
tabsize和indent.size是缩进大小,一般是设成4。
xml.auto.close.tags=1可以自动补完XML标签。
strip.trailing.spaces=1可以在保存时去掉行尾空格。
default.file.ext可以设置默认的文件类型,我当然是设成.py。
title.full.path=1可以在标题栏显示文件的完整路径。
menu.language和import部分是设置所需的语法文件,自己不用的语言就可以去掉。
刚才说到了自动完成,实际上它还支持函数补完和提示,不过也要配置。
常见的语言,如C有现成的API文件可以下载。
只要将其放在SciTE文件夹下,然后这样设置即可启用:api.*.c=$(SciteDefaultHome)\c.api
其中*.c表示文件后缀是.c,$(SciteDefaultHome)表示SciTE文件夹。
而Python是没有现成的文件的,但其实是最强大的:SciTE提供了一个gen_python script,运行(需要安装Python)后便会生成标准库和已安装的第三方库的API,然后像上面那样设置即可。
不过设置完成后还要会用它,输入一个函数,按(时会出现函数提示,这是可以自动做到的。但如果要补完的话,可以按Ctrl+I,然后就会出现API列表了。
最后,它还有个缩略语功能。
在abbrev.properties里输入“缩略词=完整词句”即可启用,支持\n等特殊字符。使用时按Ctrl+B即可。
顺便放上自己的SciTE配置文件(含Python的代码高亮文件,注意备份自己的设置)。
介绍 Zen.Coding 的文章很多,真的要掌握了还需要适应一段时间。在 Scite 下一直没有 Zen.Coding 的完整实现,官方网站也只给出了一个 Abbreviations for text editor SciTE 的简单实现。
下载后按照 README 文件里的方法设置。
下面是使用 TAB 键替换 Ctrl + B 键展开缩写的 Lua 代码,放到自启动 Lua 文件里。
function MyTab()
cp=editor.CurrentPos
scite.MenuCommand(IDM_ABBREV)
if cp==editor.CurrentPos then
editor:Tab()
end
end
在 SciTEUser.properties 文件里要有如下设置:
command.name.49.*=MyTab
command.mode.49.*=subsystem:lua,savebefore:no,groupundo
command.shortcut.49.*=Tab
command.49.*= MyTab