EXPRESSIONS & TCL Tips
This is a collection of different Expression and TCL snippets ( and some python and HTML).
I picked these from various sites, among from pages of talented TDs websites ( of which I provide a list of a few at the bottom of this page ). As it's said it is not a site explaining the Expression node, which if you're interested in I recommend you the Expressions 101 by Matt Estela and Pedro Andrade.
​
Feel free to use and share!
So what is Expression in Nuke anyway?
- Basically, programmatic commands that you can apply as parameters in Nuke.
What is TCL?
- Tcl or Tool Command Language (pronounced as `Tickle`) is a high-level, general-purpose, dynamic programming language. ( for more info here`s a Wikipedia link )
How to apply them?
- There are multiple ways, depends on what kind of expressions you want to use and for what purpose.
I recommend a few useful links from the Foundry`s website before you start to experiment with the snippets I collected:
​
Expressions on Transform
So let`s start applying some expressions!
I use a `Transform` node to show the result of the first snippets but the values it produces are the same in any node where you can add expression as the knob`s value.
And the first one should look like this:
​
data:image/s3,"s3://crabby-images/1bbda/1bbdaa3d0ac8315ff4b75d9c83c9b8c2656ceb2b" alt="001.jpg"
( You can double click on the videos to make full screen )
​
## Adding frame number as a value
x: frame OR t OR x
y: frame OR t OR x​
## Adding random number as a value ( the 'random()' generates numbers between 0 and 1 )
x: random()
y: random()
## To increase the amount of movement let's
multiply the value
x: random()*100
y: random()*100
## Adding sinus to an equation.
x: sin (frame)*100
y: sin (frame)*100
##Slow down with dividing the frame number
​
x: sin (frame/10)*100
y: sin (frame/10)*100
x: sin(frame/10)*500
rotate: sin(frame/10)*100
x: sin(frame/10)*500
rotate: cos(frame/10)*100
x: sin(frame/10)*500
rotate: cos(sin(frame/10))*100
## Movement in a circle clockwise
x: sin(frame/5)*100
y: cos(frame/5)*100
## Movement in a circle counterclockwise
​
x: cos(frame/5)*100
y: sin(frame/5)*100
Displaying knob value
data:image/s3,"s3://crabby-images/2f788/2f78860ee3c623e6e74b4b71aa1bef4a1a8dd0be" alt="002.jpg"
size: [value size]
​
data:image/s3,"s3://crabby-images/d4bab/d4bab692ecd34e5a99d4e70d5cfd73bc2fb70609" alt="003.jpg"
A channels: [value Achannels]
B channels: [value Bchannels]
data:image/s3,"s3://crabby-images/f5391/f5391c6d5e4e2a7435f6cec9faffbd6fa0685ce3" alt="004.jpg"
Range: [value range]
Range A: [value range.A]
Range B: [value range.B]
data:image/s3,"s3://crabby-images/b0834/b0834a695679d2543781b0a4d7a35e4fabaf551e" alt="005.jpg"
Mode: [value mode]
RGB: [value red], [value green], [value blue]
data:image/s3,"s3://crabby-images/70f18/70f18794451aa5700fc5d2c0b763ee4da2dd6c23" alt="006.jpg"
Gain: [value white]
data:image/s3,"s3://crabby-images/e09f9/e09f9155800c4cb4505515c8decd1e761fed410a" alt="007.jpg"
[value first_frame] - [value last_frame]
​
Format expressions
## Using the input format values
x: input.format.x
​
y: input.format.y
​
r: input.format.r OR input.width OR input.w
​
t: input.format.t OR input.height OR input.h
## Using the input format in Reformat node. ( Only works if connected node has format information like Read node )
input.format
## Using the root values ( root values are the ones in the Project Settings which you see on the Properties if you press S on the Node Graph )
x: root.format.x
​
y: root.format.y
​
r: root.format.r OR root.width OR root.w
​
t: root.format.t OR root.height OR root.h
## Using a root value in a Reformat node.
root.format
## Using the bounding box values
x: bbox.x
​
y: bbox.y
​
r: bbox.r OR bbox.width
​
t: bbox.t OR bbox.height
Frame expressions
## To return current frame value
frame OR t OR x
## Using range values from input.
input.first_frame
input.last_frame
## Using range values from root.
root.first_frame
root.last_frame
Useful Conditional expressions
## If frame number is lower than 1010 value is 0 else 100.
frame < 1010 ? 0 : 100
## If 'Transform1' translate.x value is 100 the value is 500 else 0
[if {[value Transform1.translate.x]==100} {return "500"} {return "0"}]
## If frame number is 100 the value is 500 else 0
[if {[frame]==100} {return "500"} {return "0"}]
## If knob 'test' is '0' return "hi" else "bye" - with TCL
[if {[numvalue parent.test] == 0} {return "hi"} else {return "bye"}]
[python -eval {"hi" if nuke.thisParent()['test'].array()[0] else "bye"}]
## If Text1 node's 'message knob has "Notes:" feature the note else leave empty.
[python -eval {nuke.toNode("Text1")["message"].value().split("Notes:")[1].split("\n")[0] if "Notes:" in nuke.toNode("Text1")["message"].value() else "" }]
Conditional expressions for 'disable' knob
## If frame number is greater than 1010 value is 1 ( = node is disabled )
frame > 1010
## Between frame 1010 and 1015 value is 1 ( = node is disabled )
inrange (frame, 1010, 1015)
## You can also add multiple ranges
( formula: inrange (frame, start, end, start, end, start, end) )
inrange (frame, 1010, 1015, 1025, 1035)
## Gui ( Graphic User Interface ) returns 1 ( = node is disabled ) when Nuke is running. It works well on heavy nodes when you run your render on a renderfarm.
$gui
## When the script is in use returns 1 else 12.
$gui ? 1 : 12
TIP: You can use $gui in a Switch node putting heavy nodes like Defocus on input 1 and Blur can be used while working on input 0.
For more about $gui click here.
## True if the name item exists. ( Useful for gizmos with mask input )
![exists parent.input1]
You can find more conditional TCL functions here.
Changing knob values
data:image/s3,"s3://crabby-images/9d812/9d8124c25fa8b32f2217e510aed9f7e17d67a21f" alt="008.jpg"
[knob Blur15.size 200]
After you call a knob function you need to define the node`s then the knob`s name before you give a new value to it.
data:image/s3,"s3://crabby-images/8128f/8128fc54d741372436c8b43472fb84987ba0c9fa" alt="009.jpg"
[knob Blur13.size Blur_CONTROL_2.size*3]
[knob Blur13.channels rgb]
[knob Blur13.mix .8]
You can also define multiple values from one node and can use expressions as value.
data:image/s3,"s3://crabby-images/52850/52850eae43cd3cfd6f5aaac60785483362d41772" alt="010.jpg"
[knob rotate frame]
You can also add expression as a value like frame here that returns the
current frame number.
## Setting keyframe value with setkey
[setkey this.size 34 2]
If you want to set a keyframe in a different node use the node`s name instead of this.
After defining the knob the first number is the frame number the second is the value.
Displaying input's name
data:image/s3,"s3://crabby-images/1951e/1951ef6937a2c244c1e01a49e364b27b3be6f2f5" alt="011.jpg"
## Showing single input
​
Input: [value input.name]
data:image/s3,"s3://crabby-images/0456f/0456fd5dc76c9635952a0b8d2f752efa27ea7ace" alt="012.jpg"
## Showing multiple inputs using input's
Input B: [value input0.name]
Input A: [value input1.name]
data:image/s3,"s3://crabby-images/76daf/76dafec7f382d27c8e1289065fa3dcf0aba08050" alt="013.jpg"
## Showing all inputs with python
[python {"\n".join(["Input: %s" % node.name() for node in nuke.thisNode().dependencies()])}]
Displaying pixel value
data:image/s3,"s3://crabby-images/9227b/9227b28b5d06f8c662aadc6271ebb42448ad2671" alt="014.jpg"
# In the ColorWheel
​
R: [sample [node ColorWheel5] red 1075 378]
G: [sample [node ColorWheel5] green 1075 378] B: [sample [node ColorWheel5] blue 1075 378]
# In the Grade:
​
R: [sample [node this] red 1075 378]
G: [sample [node this] green 1075 378]
B: [sample [node this] blue 1075 378]
A: [sample [node this] alpha 1075 378]
Here again, you can call a node by name or with this.
After you define the channel the first number is from the X axis the second from the Y axis.
Formatting
data:image/s3,"s3://crabby-images/3aac7/3aac70e43a891e960d285e456a448d3b57c198f2" alt="049.jpg"
# Setting the number of decimals
​
Size: [format %.1f [value size]]
# Setting the number of characters
​
Filter: [format %.5s [value filter]]
You can find out more about the format function here.
Displaying different values
data:image/s3,"s3://crabby-images/9b7e3/9b7e38cb60ea9a18149a642301e7676d67bc1ec7" alt="056.jpg"
## Showing layers
layers: [layers this]
data:image/s3,"s3://crabby-images/09ad0/09ad097ff5d21e36e1712dbf62e9c72753a68521" alt="057.jpg"
## Showing channels
Channels: [channels this]
data:image/s3,"s3://crabby-images/93ef2/93ef2b2ae492f61a4bc450f9610763e96a21069b" alt="058.jpg"
## Showing node
Node: [node this]
data:image/s3,"s3://crabby-images/94844/94844eb11abc4a3d92c0364c9f10007e5c00e261" alt="059.jpg"
## List of knobs
Knobs: [knobs this]
data:image/s3,"s3://crabby-images/c3066/c30669ae6063fc9e6729fab0b3ec281e2f6511af" alt="060.jpg"
## List of values
Values: [values this]
​
All values: [values -a this]
​
Non-default values: [values -d this]
data:image/s3,"s3://crabby-images/57899/578992e7506174ee64fc3d34f4be332ceb20b2de" alt="061.jpg"
## Node info - same list of information that comes up when you select
a node and press i or nukescripts.getallnodeinfo() with python.
Info: [show_info]
data:image/s3,"s3://crabby-images/fff82/fff82ee277e96081e1b24ccc529753a65f5dfaa4" alt="062.jpg"
## Returns number of inputs
Inputs: [inputs this]
data:image/s3,"s3://crabby-images/5eace/5eace16e96b6f72b9d621036cf10944df3173d52" alt="063.jpg"
## Returns list of all plugins
Plugins: [plugins]
data:image/s3,"s3://crabby-images/f4908/f49081c4fcaad3b5e600d4efb130833b186954bf" alt="064.jpg"
## Returns list of all formats
Formats: [formats]
data:image/s3,"s3://crabby-images/7f3e7/7f3e770c3c05d0c16c72424a72036982de405b99" alt="065.jpg"
## Returns the full name, when used in Group returns with name of Group
Full name: [full_name this]
data:image/s3,"s3://crabby-images/f6274/f627490e657cb7e89b54ea5ae988b1121f02f1f5" alt="066.jpg"
## Dependent_nodes returns list of nodes that are connected via expression
Can use the lindex function to select item from the list.
Dependent node: [value [lindex [dependent_nodes this] 0].name]
data:image/s3,"s3://crabby-images/14464/14464bbb38b9ceab67bd6a992f56d26847097bad" alt="067.jpg"
## Dependencies returns list of nodes that are connected via inputs
Dependency: [value [lindex [dependencies this] 2].name]
data:image/s3,"s3://crabby-images/84df2/84df292edc132f279dbc72997124f7e28ad2cfa7" alt="068.jpg"
## Returns filename when knob exist on node
[filename this]
Using variables
## Setting a variable
[set var1 25]
In the example above with using 'set' you can add the first argument 'var1' that is the variable and then the value '25' that it stores.
## Calling the variable
$var1
With $ before the name of the variable you can add the stored value -
In this case it is 25. You also don't need the square brackets '[ ]' here!
data:image/s3,"s3://crabby-images/b9abe/b9abe3d26b4e7924c3ef5311c35a3b36216bb5fa" alt="041.jpg"
data:image/s3,"s3://crabby-images/91748/917481408afd817d82b1fa119a9cdbe30377c23d" alt="042.jpg"
When assigning value you can sample a knob value too.
[set transX [value translate.x]]
$transX
data:image/s3,"s3://crabby-images/f9b33/f9b330a0d1f27d7144dbfe084cd6e32c75e56e81" alt="044.jpg"
When using the variable can also use the 'knob' function.
[set transX [value translate.x]]
[knob size $transX]
data:image/s3,"s3://crabby-images/13dfd/13dfd2d907962f92bf80e7425e9824c870792814" alt="046.jpg"
You can also apply mathematical functions on the numerical values.
[set transX [value translate.x]]
sin($transX * 5)
data:image/s3,"s3://crabby-images/f514f/f514f76c6eefe7e9a81d876474901b931d7d041e" alt="043.jpg"
When using a different node to sample for the variable it will
be connected with an expression line! (It is green by standard but you can
change in the Preferences)
[set shotName1 [file tail [value Read1.file]]]
shot1 : $shotName1
data:image/s3,"s3://crabby-images/880fb/880fbbcb10a3e453cd2cf95234d108f372a503e8" alt="047.jpg"
You can also apply other functions on the stored strings.
[set shotName1 [file tail [value Read1.file]]]
shot1 : [string tolower $shotName1]
shot1 : [lrange [split $shotName2 _] 0 1]
Changing node's colour
## Changing node`s tile color with changing knob`s value.
[knob tile_color [value which]]
This one is for a Switch node that`s why it calls a`which` knob but you can use it with most knobs that generates numbers.
## Changing node`s tile color for 0 and 1.
[knob tile_color [ expr { [value which]? 814350335 : 4284416255 }]]
Displaying all root info
Root info
name: [value root.name]
project directory: [value root.project_directory]
frame range: [value root.first_frame] - [value root.last_frame]
fps: [value root.fps]
format: [value root.format]
proxy mode: [value root.proxy_type]
proxy scale: [value root.proxy_scale]
read proxy files: [value root.proxySetting]
color management: [value root.colorManagement]
OCIO config: [value root.OCIO_config]
monitor: [value root.monitorLut]
8bit files: [value root.int8Lut]
16bit files: [value root.int16Lut]
log files: [value root.logLut]
float files: [value root.floatLut]
views: [value root.views]
Commands for Text node
data:image/s3,"s3://crabby-images/3172f/3172fadad5115360244fff8f3ea9f19026ee821f" alt="015.jpg"
## Showing all metadata's name (value not included) ##
​
[metadata]
​
data:image/s3,"s3://crabby-images/61670/61670fd2a7c79679a13e146213490797f6d64e54" alt="016.jpg"
## Showing certain metadata ##
​
Input/timecode: [metadata input/timecode]
Input/ctime: [metadata input/ctime]
Input/filesize: [metadata input/filesize]
Input/filereader: [metadata input/filereader]
data:image/s3,"s3://crabby-images/ee131/ee131c217730a2a114db18d4df59aca2dc13c9fb" alt="017.jpg"
## Showing date in different ways​ ##
[clock format [clock seconds]]
[date]
data:image/s3,"s3://crabby-images/0dc76/0dc760767f5fdbd6fc13260aa2718174fcbc26db" alt="019.jpg"
## Showing frame number in different ways ##
​
Frame: [value frame]
​
Frame: [python {nuke.frame()}
data:image/s3,"s3://crabby-images/a7701/a770110d911d4aeecf2cc92cfbcf81fbe56cdbfc" alt="020.jpg"
## Getting value with Node`s name ##
​
Node name: [value Read15.name]
File name: [lrange [split [basename [value [topnode].file]] .] 0 0]
File: [value Read15.file]
Format: [value Read51.format]
Frame Range: [value Read15.origfirst] - [value Read15.origlast]
Colorspace: [value Read15.colorspace]
data:image/s3,"s3://crabby-images/4f184/4f184b0bc73f9236580d10bae454fe80f82c07e1" alt="021.jpg"
## Breaking down values ##
​
Root dir: [file dirname [knob [topnode].file]]
File name: [file tail [knob [topnode].file]]
Shot name: [lrange [split [file tail [knob [topnode].file]] _ ] 0 1 ]
File extension: [file extension [knob [topnode].file]]
data:image/s3,"s3://crabby-images/ba1d6/ba1d60822dc35f8e32116a33eeb21fb07e8bbb43" alt="022.jpg"
## Show filtered metadata (value not included) ##
​
[metadata keys *time*]
data:image/s3,"s3://crabby-images/7e452/7e45296117681bf4930927edad560aac9860f7b3" alt="018.jpg"
## Time and Date in TCL ##
​
[date %%] a literal %
[date %a] weekday name (Sun..Sat)
[date %A] full weekday name (Sunday..Saturday)
[date %b] abbreviated month name (Jan..Dec)
[date %B] full month name (January..December)
[date %c] Unix style (Sat Nov 04 12:02:33 EST 1989)
[date %d] day (01..31)
[date %D] date (mm/dd/yy)
[date %e] day of month, blank padded ( 1..31)
[date %h] same as %b
[date %H] hour (00..23)
[date %I] hour (01..12)
[date %j] day of year (001..366)
[date %k] hour ( 0..23)
[date %l] hour ( 1..12)
[date %m] month (01..12)
[date %M] minute (00..59)
[date %p] AM or PM
[date %r] time, 12-hour (hh:mm:ss [AP]M)
[date %s] Unix seconds [date %S] second (00..60)
[date %T] time, 24-hour (hh:mm:ss)
[date %U] week number with Sunday as first day of week (00..53)
[date %V] week number with Monday as first day of week (01..53)
[date %W] week number with Monday as first day of week (00..53)
[date %w] day of week (0..6), Sunday = 0
[date %x] (mm/dd/yy)
[date %X] time, 24-hour (hh:mm:ss)
[date %y] year (00..99)
[date %Y] year (1970..)
[date %z] RFC-822 style numeric timezone (-0500)
[date %Z] time zone (e.g., EDT)
You can find more TCL functions that are useful in Text nodes HERE.
Display metadata
data:image/s3,"s3://crabby-images/04ff7/04ff728eb9ff71a8ffa97115bfbb455432b05aa7" alt="074.jpg"
[metadata]
Display all metadata keys
data:image/s3,"s3://crabby-images/6a60a/6a60afbaebdb321353e103a551a92b1029a45405" alt="075.jpg"
[python {"/n".join(nuke.thisNode(). metadata())}]
Display all metadata keys with python
data:image/s3,"s3://crabby-images/d9b17/d9b17971cc4deb0ca86674e8811453bd00cea071" alt="076.jpg"
[metadata input/timecode]
Display specific metadata's value
data:image/s3,"s3://crabby-images/1695b/1695bf7bae22f63eedc8cedd99ee8202fda7d768" alt="077.jpg"
[python {nuke.thisNode(). metadata().get("input/timecode")}]
Display specific metadata's value with python
data:image/s3,"s3://crabby-images/597b9/597b97374e56859a9ba6314a8ca984cd231c488d" alt="078.jpg"
[metadata keys *time]
Display filtered metadata keys ( ones that end with "time" here )
data:image/s3,"s3://crabby-images/08a25/08a2529ff933f4f596816a1533105653427b5de3" alt="079.jpg"
[python -exec {
timeMetas = []
for i in nuke.thisNode().metadata():
if i.endswith("time"):
timeMetas.append(i)
timeMeta = ('\n '.join(timeMetas))
}] [python timeMeta]
Display filtered metadata keys with python ( ones that end with "time" here )
data:image/s3,"s3://crabby-images/51a7e/51a7e6e758df8ed321ebd146a116061b7fcf7bff" alt="080.jpg"
[metadata keys]
Display all metadata keys
data:image/s3,"s3://crabby-images/a9b1e/a9b1e31024e5ffe7a88fba2a96612c6959e6e171" alt="081.jpg"
[metadata values]
Display all metadata keys with values
data:image/s3,"s3://crabby-images/274e6/274e63037b63debb457e9b296553ff9aaaf34447" alt="080.jpg"
[metadata -s "\n " keys input/*]
Display filtered metadata keys with custom separator ( ones that starts with "input/" here )
data:image/s3,"s3://crabby-images/67f00/67f008d270ddee2420ae3c1ffb437d9302426c7b" alt="083.jpg"
[metadata -v ": " values]
Display metadata keys with values using custom separator
data:image/s3,"s3://crabby-images/8413d/8413d84e8b97e463c105183a4e393c1d80753609" alt="084.jpg"
[metadata -v ": " values *time*]
Display filtered metadata keys with values using custom separator
( ones that includes "time" here )
data:image/s3,"s3://crabby-images/9d306/9d306a0a21326afd60f2874f0b8525878184cc29" alt="085.jpg"
[metadata -n Read15 values]
Display metadata keys with values from specific node
data:image/s3,"s3://crabby-images/6c492/6c4924352482a0dfb9dde7724d3eafa5d363a004" alt="086.jpg"
[metadata -n Read15 input/timecode]
Display metadata value from specific node
Referencing Foundry page.
Adding images / emojis to nodes with html
data:image/s3,"s3://crabby-images/284ec/284ec16155107a6c462d899bc064fb89fb2028a8" alt="023.jpg"
<img src= "Shuffle.png">
You can add the image of any default node icon by putting its name instead of the `Shuffle`​.
data:image/s3,"s3://crabby-images/f2510/f2510286f4947fa88b3289043e877939821feb67" alt="024.jpg"
data:image/s3,"s3://crabby-images/923b7/923b7cde29585ba4a75101215af2d09744b945c9" alt="025.jpg"
<img src= "D:/gatimedia_white_logo.png">
You can also add any image to a label, just copy the path between the quotation marks.
Even more fun is that you can use emojis in Nuke!
In this example I added the code to the Text knob
data:image/s3,"s3://crabby-images/cd9df/cd9df3aa48f5aa37756dd842f6dd5dbe9363ed9a" alt="069.jpg"
<p style="font-size:100px">🦁</p>
The code is from here where you can find a lot more codes for different emojis.
There is a site also for smiley emojis and for different skin tones!
​
In this fomula you can adjust the size ( which is 100px here ),
and which emoji you want to display by changing the decimal code ( which is 129409 here ).
data:image/s3,"s3://crabby-images/a8053/a8053ba09a23d239a4af129071b51dd478dfe82f" alt="070.jpg"
<p style="font-size:100px">🤘🏿</p>
For changing the skin tone you need to use two decimal codes - first for the type of emoji and the second one for the skin tone.
data:image/s3,"s3://crabby-images/183fd/183fdbbe73450059568554386b96a0d941c5bcc8" alt="071.jpg"
<p>I will display 🦁</p>
Can also use the decimal code without setting the size and it will be the size of the text.
Make sure you define the paragraph before and after ( <p> - start, and </p> - end ),
otherwise it will only appear as a text.
data:image/s3,"s3://crabby-images/e9126/e91262b4980d8cdcddb7e7226b8b6989099a0f75" alt="072.jpg"
You can also add emojis to the label but it might won't look as expected.
data:image/s3,"s3://crabby-images/d328a/d328a6b146607ddc0053f7ba813cca0b01778981" alt="073.jpg"
Also can use them as name of the user knobs.
Text editing with html
data:image/s3,"s3://crabby-images/1db08/1db089f40504511d2976f356e005c6b6edfd6b04" alt="026.jpg"
## Center ##
​
<center>Lorem Ipsum</center>
data:image/s3,"s3://crabby-images/a66b0/a66b0a6e82d9f7f95e27851df2c837963455c945" alt="028.jpg"
## Italic ##
​
<i>Lorem Ipsum</i>
data:image/s3,"s3://crabby-images/efcbd/efcbd8bc866826a4ad1a7ddb4a765b720bea0b1a" alt="030.jpg"
## Strikethrough ##
​
<s>Lorem Ipsum</s>
data:image/s3,"s3://crabby-images/7b40e/7b40ead1227b9562c44b89786bd31550383dea8f" alt="031.jpg"
## Changing font colour with Hex code ##
​
<font color=#582b00>Lorem Ipsum</font>
data:image/s3,"s3://crabby-images/e852e/e852e58320d84562acc3edb266e401458fa66a71" alt="035.jpg"
## Superscript ##
​
Lorem <sup>Ipsum</sup>
data:image/s3,"s3://crabby-images/27db8/27db81f2d4f0d7d005ab3d131b6e35297d09f8b5" alt="036.jpg"
## Align text to the right 1 ##
​
<p style="text-align:right">Lorem Ipsum</p>
data:image/s3,"s3://crabby-images/6167a/6167a58ff7fca6fc62d94944ed6560e77945b780" alt="037.jpg"
## Strong ##
​
<strong>Lorem Ipsum</strong>
data:image/s3,"s3://crabby-images/e5fb5/e5fb525acd900090d986117273cfcc5653a4d718" alt="039.jpg"
## Small ##
​
<small>Lorem Ipsum</small>
data:image/s3,"s3://crabby-images/d4c54/d4c545a74ee62697be31188d260e768e8711e6cc" alt="027.jpg"
## Bold ##
​
<b>Lorem Ipsum</b>
data:image/s3,"s3://crabby-images/50e6a/50e6a931cabbff7ebb2618edf49a4e6ca1b17169" alt="029.jpg"
## Underline ##
​
<u>Lorem Ipsum</u>
data:image/s3,"s3://crabby-images/dd4f3/dd4f37f9a7bc950fafb1df1d54ec5e40c4955edf" alt="033.jpg"
## Font size ##
​
<font size="5">Lorem Ipsum</font>
data:image/s3,"s3://crabby-images/49fe9/49fe916100b0a3e979b5b93c9e2680077d839433" alt="032.jpg"
## Changing font colour with colour`s name ##
​
<font color=aqua>Lorem Ipsum</font>
data:image/s3,"s3://crabby-images/ecd21/ecd215c6575cd0769006a8f6ff5e5d9cd79dc405" alt="034.jpg"
## Subscript ##
​
Lorem <sub>Ipsum</sub>
data:image/s3,"s3://crabby-images/27db8/27db81f2d4f0d7d005ab3d131b6e35297d09f8b5" alt="036.jpg"
## Align to the right 2 ##
​
<p align="right">Lorem Ipsum</p>
data:image/s3,"s3://crabby-images/a5622/a5622c485238724bcbcb2f73f1d39f2b7190f834" alt="038.jpg"
## Big ##
​
<big>Lorem Ipsum</big>
data:image/s3,"s3://crabby-images/195ca/195ca5e8a85428498dff30e2f46b9b3307d789be" alt="040.jpg"
## Emphasized ##
​
<em>Lorem Ipsum</em>
data:image/s3,"s3://crabby-images/afa23/afa2348f279cf0479db015e5b0d4afa34dafc1c9" alt="051.jpg"
## Headers ##
​
<h1>Lorem Ipsum</h1>
<h2>Lorem Ipsum</h2>
<h3>Lorem Ipsum</h3>
​
​
<h4>Lorem Ipsum</h4>
<h5>Lorem Ipsum</h5>
Lorem Ipsum
data:image/s3,"s3://crabby-images/d9f3d/d9f3d6a274d144aa8fdb3f8929b13d795dd186e1" alt="052.jpg"
## Adding a link to a node using a Text knob ##
​
<a href="https://www.gatimedia.co.uk/">Visit my page!</a>
Environment variables
data:image/s3,"s3://crabby-images/75e9a/75e9ad6e041c0c177fec3b2656bb76c4d4ebdca8" alt="053.jpg"
## Using python in the script editor to print all env variables ##
​
import os
for k,v in sorted(os.environ.items()):
print (k,": ",v)
You can find out more about how to use python snippets HERE.
data:image/s3,"s3://crabby-images/aa6d0/aa6d016f6df4b626cff0038b5b320324b08ffb9b" alt="054.jpg"
## Using TCL to print all env variables ##
​
[array get env]
​
## Search in the array
​
[array get env *NUKE*]
data:image/s3,"s3://crabby-images/07e52/07e52709ff7df5535600d5730e49fde5bd66317c" alt="055.jpg"
## Using TCL to print specific env variable ##
​
[getenv NUKE_TEMP_DIR]
Useful links
If you want to dig deeper into the wonderful ( and often frustrating ) world of TCL commands in Nuke you should visit Nuke TCL Scripting Documentation.
Hope you will find it useful!