Matlab代码格式一键美化神器

MBeautifier是一个基于MATLAB源代码的开源一键美化m代码的格式器。它可以直接在MATLAB编辑器中使用,并且可按照使用者习惯进行配置的。MBeautifier支持的Matlab最低版本是R2013b。

MBeautifier的原始下载地址:https://github.com/davidvarga/MBeautifier

下载不方便的读者可以在公众号后台发送关键字:MBeautifier,即可获取百度网盘下载链接。

MBeautifier是一种基于M-Script的轻量级MATLAB源代码格式化程序,可直接在MATLAB编辑器中使用。

特点

  • 用空格填充运算符和关键字

  • 可配置缩进字符和级别。使用MATLAB编辑器的智能缩进功能进行缩进

  • 移除/添加连续空行

  • 在矩阵和单元数组初始化中插入缺少的元素分隔符(逗号)

  • 在矩阵和单元数组初始化中插入缺少的连续符号行

  • In-lining连续线

  • 格式化MATLAB编辑器的当前页面或仅在MATLAB编辑器或文件中选择一个选项

  • 而上面的一切都可以在一个XML文件中配置

部署和配置

只需将下载的zip文件解压到特定的目录,然后把MBeautifier的根目录添加到MATLAB路径。

配置Configuration

可以通过编辑MBeautifier\resources\settings\MBeautyConfigurationRules.xml文件来修改配置。

配置规则

目前实现了三种配置规则:Operator padding ruleKeyword padding ruleSpecial rule

运算符填充规则

每个OperatorPaddingRule表示单个运算符的格式规则,由一个键、应替换的字符串和用于替换的字符串组成。

<OperatorPaddingRule>
  <Key>NotEquals</Key>
  <ValueFrom>~=</ValueFrom>
  <ValueTo> ~= </ValueTo>
</OperatorPaddingRule>

上面的示例显示了“不等于”运算符的规则。

ValueFrom节点存储运算符~=

ValueTo节点存储预期格式:运算符前面和后面都应该有white-space字符。

关键字填充规则

每个KeyworPaddingRule表示单个关键字的格式规则,并由关键字本身和右侧所需的white-space填充的数值组成。

<KeyworPaddingRule>
<Keyword>properties</Keyword>
<RightPadding>1</RightPadding>
</KeyworPaddingRule>

上面的例子显示了关键字“properties”的规则。RightPadding节点存储预期的右填充空白量:关键字前面应该有一个空白字符。

注意:并不是所有的关键字都列出了-只有那些控制填充有意义的关键字。

特殊规则

这些规则基本上是MBeautifier某些功能的开关。详情可以见压缩包的README.md文件,

使用方法,直接在命令行输入使用

目前支持四种方法:

  • 在MATLAB编辑器的当前活动页面上执行格式化。命令:MBeautify.formatCurrentEditorPage()。默认情况下,不会保存文件,但仍会在编辑器中打开并修改。可以选择使用MBeautify.formatCurrentEditorPage(true)语法保存格式化的文件。

  • 对MATLAB编辑器活动页面的当前选定文本执行格式化。命令:MBeautify.formatEditorSelection()。在这种情况下,还存在如上所述的可选保存机制。(这个功能实测下来不知道为啥运行时间比较长,不推荐了)

  • 对文件执行格式化。命令:MBeautify.formatFile(file)。可以与(1)一个参数一起使用:输入文件已格式化,并且在MATLAB编辑器中保持打开状态,未保存;(2)两个参数为MBeautify.formatFile(file, outFile):如果可能,将格式化的文件保存到指定的输出文件中。输出可以与输入相同。file需要绝对路径

  • 对目录中的多个文件执行格式化。命令:MBeautify.formatFiles(directory, fileFilter)。第一个参数是指向目录的绝对路径,第二个参数是一个通配符表达式(用于dir命令),用于过滤目标目录中的文件。文件将被格式化in-place(覆盖)。

猜你喜欢

转载自blog.csdn.net/qingfengxd1/article/details/125432405