SAS程序猿/媛在跑程序之前通常要进行一些设置,比如清除日志和输入窗口等;在程序跑完之后,又需要检查数据集的结果,比如查看某一特定的行或者特定的变量的值是否正确,如果这些通过菜单来操作,那可能会不方便且浪费时间。好在我们可以通过DM语句来快速地完成这些工作。使用方法有多种,如果不需要交互有以下几种途径:在程序编辑窗口直接提交对应的代码、设置快捷键、定制工具栏或者在工具栏通过GSUBMIT命令直接执行命令。需要交互时的途径有:通过GSUBMIT命令直接输入命令、设置快捷键。下面 以需要在一个较的数据集中快速定位特定变量或者特定的行为例来介绍需要交互时的途径:
- 通过GSUBMIT命令直接输入命令,如要快速定位某一数据集的第1117行以及显示某一特定的变量A:
gsub "dm _last_ 'forward 1116;' continue;" gsub "dm _last_ 'show A;' continue;"
- 如果觉得上面的方法麻烦的话,可以把命令放到程序中(如tool.sas),然后设置一个VT快捷键(如F1)来执行这个程序。如下图: 完整的步骤如下:首先要建WINDOW语句来建一个交互窗口以便输入特定的行数或者特定变量的名字,程序如下:
%let line=; %let name=; %window Tool irow = 10 rows = 15 icolumn = 10 columns = 90 color=white #3 @18 'To show the desired variable or desired line.' color=blue #5 @18 'Enter line number:' color=blue #7 @18 'Enter variable name:' color=blue #9 @18 'Note: variable name should be separated by a single space.' color=blue #5 @37 line 15 attr=underline #7 @39 name 15 attr=underline; %display Tool;
接下来执行DM语句:
%macro tool; %if &line^= %then %do; dm _last_ "top" continue; dm _last_ "forward %eval(&line-1)" continue; %end; %if &name^= %then %do; dm _last_ "show ""&name""" continue; %end; %mend tool; %tool
设置成功后,当你打开数据集按F1时,就会弹出如下的对话框: