Command macros and scripting

All Rhino commands can be used in command macros. Command macros can be run by typing the command at the command prompt, from toolbar buttons, shortcut keys, command aliases, from the ReadCommandFile command, or using the Paste command into Rhino's command stream.

Writing Command Macros

Write command macros just as you would type the command sequence at the command line.

Special characters

Meaning in macro

(Space)

A space character in macros acts like pressing Enter.

When scripting a name (or a text string) that contains spaces, you need to enclose it in double-quotes to avoid breaking the command sequence.

For example:

_-SelName "Table 01"

_-SelName Table 01

*
(asterisk)

Causes the command to repeat automatically without pressing Enter to restart.

!
(exclamation point)

Cancels the previous command.

An exclamation point (!) in the beginning of a macro cancels any previous command. At other locations, it cancels the macro. If necessary, the exclamation point can be used at the end of the macro.

-
(hyphen / dash)

Suppresses dialog box.

Basically, all commands can be made into macros at the command line (even commands that have dialog boxes by default). To suppress the dialog box and use command-line options, prefix the command name with a hyphen (-). A few commands (e.g., DevLoft) have options only available at the command-line.

_
(underscore)

Runs commands and options in English.

Rhino is localized in several languages. Commands and options are translated differently in different languages. To make macros work worldwide, we suggest writing macros in English with an underscore in front of every command and option.

For example:

Cerchio 3Punti 0,0,0 1,1,0 0,3,0

This macro only works in the Italian version of Rhino.

 

_Circle _3Point 0,0,0 1,1,0 0,3,0

This macro works in all language versions of Rhino.

'
(apostrophe)

The next command is a nestable command.

View and construction plane manipulation and object snaps are nestable. Geometry creation commands are not nestable.

One-shot object snaps and sub-object picking filters are automatically nestable and do not require an apostrophe.

\
(backslash)

If the last character in a toolbar button macro is "\", the macro runs without proceeding Enter at the end.

For example:

Create a toolbar button with a macro "5\". Clicking the button enters 5 to the command line and stops there for further input. This feature can be used to create a toolbar that works like an on-screen numeric keypad.

~
(tilde)

Suppresses command options for clutter free command feedback. The options still work as usual.

;

(semicolon)

Comment.

Lines beginning with a semicolon (;) are not part of the macro, but let you document the macro or try alternative input.

For example:

; This is a test macro
_Circle 0,0,0 15
_Line 0,0,0 pause ;15,0,0
; Line 0,0,0 0,15,0
_Line 0,0,0 -15,0,0

::
(double colon)

Layer nesting is indicated by a double colon - "::" between layer names. In the -Layer command, add a new layer nested under Layer 01 using a macro like this:

! _-Layer New "Layer 01:: New Layer" Enter

#
(hash)

Enables history recording for the following command.

For example: #ArcBlend

%
(percent)

Disables history recording for the following command.

For example: %ArcBlend

!&

(exclamation point + and)

Disables History locking in a command session.

For example: !&_Delete and !&_Join

Examples

Draw a circle

This macro creates a circle centered at 5,5 with a radius of 10:

! _-Circle 5,5 10

The spaces between the entries are the same places you would press Enter when typing the command by hand.

Deselect objects and start the Move command

This macro starts the Move command, but makes sure no objects are selected before asking you to select objects to move:

! _SelNone _Move

Create a curve through points

This macro creates a set of three points, selects them all, and fits a polyline through the points:

! _SelAll _Points _Pause _Pause _Pause _Enter _Invert _CurveThroughPt _EnterEnd

How this script works:

! _SelAll

Cancels all previous commands and selects all the objects currently in the model.

_Points

Runs the Points command.

_Pause

_Pause

_Pause

Allows picking three point locations.

_Enter

Simulates pressing Enter, which stops the creation of point objects.

_Invert

Inverts the selection. All visible objects in the scene were selected at the beginning of the script, so after Invert only the newly created point objects are selected.

_CurveThroughPt

Creates a polyline through the point objects.

_EnterEnd

Completes the command.

Bypass a dialog box

! -_Rebuild _Pause _Points=10 _Degree=3 _Enter

Select a curve, then run this macro. All options will be set by the macro.

To try these scripts

  1. Select the macro right from this Help topic.
  2. Press Ctrl + C to copy it to the Clipboard.
  3. Click in the Rhino command prompt, and press Ctrl + V to paste the macro.
Special scripting commands

Pause

Stops for user input in a macro.

Example:

! _Circle _Pause 50

This macro asks for a point and then draws a circle with a 50 unit radius centered there.

MultiPause

Stops a script for the duration of multiple selections, for example in Join, Polyline, and FilletEdge.

Enter

Simulates pressing Enter inside a macro.

This command does not repeat the previous command like pressing Enter does.

EnterEnd

Completes the command.

SetRedrawOff

Prevents screen redraw, construction plane or camera changes during macros.

SetRedrawOn

Turns screen redraw back on after SetRedrawOff.

NoEcho

Turns off echoing of macro commands to the command history window.

Echo

Turns on echoing of macro commands to the command history window.

If you do not know what to type in a macro, run the hyphenated version of the command. Highlight and copy the command sequence and paste it into your macro text as a starting point.

MacroEditor

Toolbar Menu

Tools

Window

Panels > Macro Editor

The MacroEditor command opens an edit window for macro creation and testing.

Macro Editor panel

Container options

Steps

  1. Type commands and options in the Macro Editor window.

  2. Click the button to test the macro.

Toolbar

Run

Executes the whole macro, or the highlighted part of the macro.

Delete

Clears the editing box.

Context menu

Cut

Copies the selected text to the clipboard and deletes the text.

Copy

Copy the selected to the clipboard.

Paste

Inserts the text stored in the clipboard to the cursor location.

ReadCommandFile

Toolbar Menu

Tools

Tools

Commands >

Read from File

The ReadCommandFile command reads and executes a command macro from a text file.

Steps

  • In the Open Text File dialog box, select the file to read.
    The file contents are copied into the command line, and the lines of the command file are interpreted as if they were typed into the command line.

Notes

  • When building command files, use the Enter command, which is equivalent to pressing Enter to execute commands.
  • If you read in a particular file often, assign ReadCommandFile to a toolbar button along with a filename. For example: -ReadCommandFile myfile.txt
  • If the file name has spaces, surround the text with quote marks. For example: -ReadCommandFile "my file.txt".

Example

Make a text file like the following example that has commands for creating all your curves in it, and then create the curves all at once with ReadCommandFile.

! _interpcrv
23,5,0
23.2,5,0
23.7,5.2,1
_Enter
_interpcrv
26.1,4.9,1.1
26.8,4.9,1.0
27.1,4.8,0.9
_Enter

etc&.

Echo

Toolbar Menu

Not on toolbars.

Not on menus.

The Echo command turns on echoing of macro commands to the command history window.

To turn echoing off, use the NoEcho command.

NoEcho

Toolbar Menu

Not on toolbars.

Not on menus.

The NoEcho command turns off display of macro commands in the command history window.

  • To turn echoing on use the Echo command.

NoEcho or _NoEcho needs to be the very first word in the macro for it to work properly. Everything, including the exclamation point should follow, separated by a single space.

Enter

Toolbar Menu

Not on toolbars.

Not on menus.

The Enter command functions as pressing Enter for use in scripts or toolbar button programming.

Example

This script sets a construction plane by three picked points:

'_CPlane _3Point

_Pause _Pause _Pause _Enter

The Enter command does not repeat the previous command like pressing the Enter key does.

EnterEnd

Toolbar Menu

Not on toolbars.

Not on menus.

The EnterEnd command functions as pressing the Enter key to complete a command string for use in macros or toolbar button programming.

EnterEnd is handy when a command is deep, in terms of command options such as Options or DocumentProperties, and you want to exit after one of these without counting how many Enters you need to get back to a blank command prompt. For example:

! _-DocumentProperties _Mesh _Custom _MaxEdgeSrf .01

would require at least two or three enters to exit the command. With EnterEnd, the command exits as soon as you want it to.

Example

! _-DocumentProperties _Mesh _Custom _MaxEdgeSrf .01 _EnterEnd

Close

Toolbar

Menu

Not on toolbars.

Not on menus.

The Close command can be used in a script to close a Rhino model.

  • The command requires a path to the file to close; otherwise it does nothing.

Python script example:

import Rhino

import scriptcontext as sc

Rhino.RhinoApp.RunScript("Close "+sc.doc.Path+" Enter", False)

Exit

Toolbar

Menu

Shortcut

Not on toolbars.

Rhino

Quit Rhinoceros

Ctrl (CMD) + Q

The Exit command closes the current Rhino session.

Pause

Toolbar Menu

Not on toolbars.

Not on menus.

The Pause command stops a macro for user input.

Example

This macro asks for a point and then draws a circle with a 50 unit radius centered there.

! _Circle _Pause 50

MultiPause

Toolbar Menu

Not on toolbars.

Not on menus.

The MultiPause command stops a macro for user input.

Example

This macro asks for objects to join.

! _Join _MultiPause

Run

The Run command runs another application from inside Rhino.

Steps

  • Type the name and path of the file to run.

SetRedrawOff

Toolbar Menu

View

Not on menus.

The SetRedrawOff command disables screen redraw, construction plane, or camera changes during scripts.

To turn screen redraw back on

SetRedrawOn

Toolbar Menu

View

Not on menus.

The SetRedrawOn command enables screen redraw, construction plane, or camera changes during scripts.

To turn screen redraw off

For more information on Rhino-specific scripting, see: http://wiki.mcneel.com/rhino/basicmacros.

RunPythonScript

Toolbar

Menu

Not on toolbars.

The RunPythonScript command runs a Python script.

For the on-line Rhino.Python programmers reference, see: http://developer.rhino3d.com/guides/rhinopython.

-RunPythonScript

Options

ResetEngine

Forces the python engine to re-initialize. This is only useful while python scripts that span multiple files are being written and tested.

EditPythonScript

Toolbar

Menu

Not on toolbars.

The EditPythonScript command edits a Python script.

For more information on Rhino-specific scripting, see: http://developer.rhino3d.com/guides/rhinopython.

ScriptEditor

Toolbar

Menu

Tools

New in V8

Tools

Script > Edit

The ScriptEditor command opens the Script Editor window for Python and C# programing.

Guides of Script Editor

Command-line options

Run the scriptable command, -ScriptEditor, to access command-line options.

Edit

Opens the Script Editor window.

Run

Executes a script file.

To run a script file with a macro

You can use several ways to specify the path of the script file.

  • Use a complete file path:

    _-ScriptEditor _Run "/Users/<UserName>/Documents/My Script.py"

  • Use an environment variable in the path:

    _-ScriptEditor _Run "$HOME/Documents/My Script.py"

    _-ScriptEditor _Run "~/Documents/My Script.py"

    These macros run the "My Script.py" file in your Documents folder.

    Run the "Env" command in Terminal to list all environment variables.

  • Search the file in the folders set in Rhino Settings > Files:

    _-ScriptEditor _Run "My Script.py"

Open

Loads a script file in the Script Editor window.