Difference between revisions of "Functions"
From webCoRE Wiki - Web-enabled Community's own Rule Engine
(→Time) |
m (→formatDateTime) |
||
(87 intermediate revisions by 8 users not shown) | |||
Line 1: | Line 1: | ||
− | = | + | <div style="float: left; clear: both; margin-right: 1em; margin-bottom: 1em;">__TOC__</div> |
− | + | Functions are extensions to expressions that allow data processing and conversion. Here is a list of all defined functions | |
− | :// | + | |
− | + | ||
− | : | + | =[[Variable_data_types#String|String]] functions= |
− | ; | + | |
− | : | + | ==concat== |
− | + | :Syntax | |
− | : | + | ::<code>''string'' concat(''dynamic'' value1, ''dynamic'' value2[, .., ''dynamic'' valueN])</code> |
− | + | :Returns | |
− | : | + | ::Returns a string that is the concatenation of all the supplied values. This function accepts two or more input values. |
− | + | ||
− | : | + | ==contains== |
− | + | :Syntax | |
− | : | + | ::<code>''boolean'' contains(''string'' haystack, ''string'' needle)</code> |
− | + | :Returns | |
− | : | + | ::Returns true if the <code>needle</code> is found anywhere in the <code>haystack</code> |
− | + | ||
− | : | + | ==endsWith== |
− | + | :Syntax | |
− | : | + | ::<code>''boolean'' endsWith(''string'' haystack, ''string'' needle)</code> |
− | + | :Returns | |
− | : | + | ::Returns true if <code>haystack</code> ends with the <code>needle</code> |
− | + | ||
− | :returns the negative | + | ==format== |
− | + | [[File:Format.pdf|page=1|thumb|256px|A very nice article written by Professor Don Colton, at the Brigham Young University of Hawaii]] | |
− | : | + | :Syntax |
+ | ::<code>''string'' format(''string'' formatString[, ''dynamic'' value1[, .., ''dynamic'' valueN]])</code> | ||
+ | :Returns | ||
+ | ::Returns a string that is built based on the <code>formatString</code> with arguments replaced by their corresponding values. Follows the java syntax for <code>printf()</code>. See a quick reference [https://www.cs.colostate.edu/~cs160/.Summer16/resources/Java_printf_method_quick_reference.pdf here], or a more detailed reference [https://sharkysoft.com/archive/printf/docs/javadocs/lava/clib/stdio/doc-files/specification.htm Reference here]. | ||
+ | ::Each % in the format string represents an argument and corresponds to a value (in order of appearance) in the value list. Each argument can have formatting settings, according to the reference provided. | ||
+ | :Example | ||
+ | ::<code>format('The temperature outside is %.2f degrees Fahrenheit', [Temp sensor:temperature])</code> outputs <code>The temperature outside is 71.26 degrees Fahrenheit</code> | ||
+ | ::The <code>%.2f</code> translates to "format as <code>f</code>loat and use <code>.2</code> decimal places. | ||
+ | |||
+ | ==indexOf== | ||
+ | :Syntax | ||
+ | ::<code>''integer'' indexOf(''string'' haystack, ''string'' needle)</code> | ||
+ | :Returns | ||
+ | ::Returns the character index of the first occurrence of <code>needle</code> inside <code>haystack</code> | ||
+ | :Examples | ||
+ | ::<code>indexOf("hello world", 'l')</code> outputs <code>2</code> | ||
+ | |||
+ | ==json== | ||
+ | :Syntax | ||
+ | ::<code>''string'' json(''dynamic'' value[, "boolean" pretty])</code> | ||
+ | :Returns | ||
+ | ::Returns the JSON representation of the provided value. If the pretty parameter is true, indentation is added to improve human readability | ||
+ | :Examples | ||
+ | ::<code>json(true)</code> outputs <code>"true"</code> | ||
+ | ::<code>json(123)</code> outputs <code>"123"</code> | ||
+ | ::<code>json('Nicole "Nikki" Sawyer')</code> outputs <code>""Nicole \"Nikki\" Sawyer""</code> | ||
+ | ::<code>json(myStringList, true)</code> outputs with pretty formatting | ||
+ | :::<code>"{<br/> "name": "Jaime",<br/> "present": true<br/>}"</code> | ||
+ | ::<code>json(myDeviceList)</code> outputs <code>"[":97e051eb6fea489fa7cf1aaa4cb7c171:",":73d68350942e4555a8c47c36f558681e:"]"</code> since device variables are internally a list of device IDs | ||
+ | ::<code><nowiki>"\{"device": {json($currentEventDevice)}, "rooms": \[ {json(activeRoom)}, "Basement" \] \}"</nowiki></code> building JSON by hand in a webCoRE expression requires any <code>{}[]</code> characters in the JSON to be escaped with a backslash and all dynamic values must use the <code>json()</code> function to safely represent the value | ||
+ | |||
+ | ==lastIndexOf== | ||
+ | :Syntax | ||
+ | ::<code>''integer'' lastIndexOf(''string'' haystack, ''string'' needle)</code> | ||
+ | :Returns | ||
+ | ::Returns the character index of the last occurrence of <code>needle</code> inside <code>haystack</code> | ||
+ | :Examples | ||
+ | ::<code>lastIndexOf("hello world", 'l')</code> outputs <code>9</code> | ||
+ | |||
+ | ==left== | ||
+ | :Syntax | ||
+ | ::<code>''string'' left(''string'' value, ''integer'' length)</code> | ||
+ | :Returns | ||
+ | ::Returns the first <code>length</code> characters in <code>value</code> | ||
+ | :Examples | ||
+ | ::<code>left("hello world", 2)</code> outputs <code>he</code> | ||
+ | |||
+ | ==lower== | ||
+ | :Syntax | ||
+ | ::<code>''string'' lower(''string'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the <code>value</code> but with all lower case letters. | ||
+ | :Examples | ||
+ | ::<code>lower("Hello World")</code> outputs <code>hello world</code> | ||
+ | |||
+ | ==mid== | ||
+ | :Syntax | ||
+ | ::<code>''string'' mid(''string'' value, ''integer'' start[, ''integer'' count = remaining])</code> | ||
+ | :Arguments | ||
+ | ::<code>start</code> - provides the 0-based index of the first character to copy. If <code>start</code> is negative, the counting starts from the end of <code>value</code>. | ||
+ | ::<code>count</code> - provides the number of characters to copy from <code>value</code>. If not provided, all of the remaining characters from <code>value</code> are returned, starting with character number <code>start</code>. If <code>count</code> is negative, prior characters are returned. | ||
+ | :Returns | ||
+ | ::Returns a substring of <code>value</code>, <code>count</code> characters long, starting at character number <code>start</code>. Note that the first character in any string has index 0. | ||
+ | :Examples | ||
+ | ::<code>mid("Hello World", 2, 3)</code> outputs <code>llo</code> | ||
+ | ::<code>mid("Hello World", 2)</code> outputs <code>llo World</code> | ||
+ | ::<code>mid("Hello World", -5, 2)</code> outputs <code>Wo</code> | ||
+ | ::<code>mid("Hello World", -1, -3)</code> outputs <code>orl</code> | ||
+ | |||
+ | ==random== | ||
+ | :Syntax | ||
+ | ::<code>''dynamic'' random([''integer'' range | ''dynamic'' value1, ''dynamic'' value2[, .., ''dynamic'' valueN]])</code> | ||
+ | :Arguments | ||
+ | ::<code>range</code> - an integer number representing a range | ||
+ | ::<code>value1</code>..<code>valueN</code> - any kind of arguments, one will be randomly returned | ||
+ | :Returns | ||
+ | ::Returns a random decimal number between <code>0</code> and <code>1</code> if no arguments are provided, or a number between <code>0</code> and <code>range</code> (inclusive) if a single argument is provided, or a randomly selected argument if two or more arguments are provided. | ||
+ | :Examples | ||
+ | ::<code>random()</code> outputs <code>0.483</code> (random decimal) | ||
+ | ::<code>random(20)</code> outputs <code>6</code> (random integer) | ||
+ | ::<code>random("Hello World", "Good morning", "Hello", "Hi")</code> outputs <code>Hello</code> (randomly selected value) | ||
+ | :Tips | ||
+ | ::To output a random integer between 5 and 20 use <code>(5 + random(15))</code> | ||
+ | ::To output a random integer between -5 and 20 use <code>(-5 + random(25))</code> | ||
+ | |||
+ | ==replace== | ||
+ | :Syntax | ||
+ | ::<code>''string'' replace(''string'' haystack, ''string'' needle1, ''string'' replacement1[, .., ''string'' needleN, ''string'' replacementN])</code> | ||
+ | :Returns | ||
+ | ::Replaces all the occurrences of <code>needle</code> inside <code>haystack</code> with its respective <code>replacement</code>. Multiple pairs of <code>needle</code>/<code>replacement</code> can be provided in one function call. | ||
+ | :Regular expressions | ||
+ | ::Needles support regular expressions when their value starts and ends with a <code>/</code>. For example, <code>'/(\s)/'</code> will match all spaces. | ||
+ | :Examples | ||
+ | ::<code>replace("Hello World", 'World', 'Earth')</code> outputs <code>Hello Earth</code> | ||
+ | ::<code>replace("Hello World", 'World', 'Earth', 'Hello', 'Hi')</code> outputs <code>Hi Earth</code> | ||
+ | ::<code>replace("Hello World", 'World', 'Earth', 'Earth', 'Planet')</code> outputs <code>Hello Planet</code> | ||
+ | |||
+ | ==right== | ||
+ | :Syntax | ||
+ | ::<code>''string'' right(''string'' value, ''integer'' length)</code> | ||
+ | :Returns | ||
+ | ::Returns the last <code>length</code> characters in <code>value</code> | ||
+ | :Examples | ||
+ | ::<code>right("hello world", 4)</code> outputs <code>orld</code> | ||
+ | |||
+ | ==startsWith== | ||
+ | :Syntax | ||
+ | ::<code>''boolean'' startsWith(''string'' haystack, ''string'' needle)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>haystack</code> starts with the <code>needle</code> | ||
+ | |||
+ | ==string== | ||
+ | :Syntax | ||
+ | ::<code>''string'' string(''dynamic'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns <code>value</code> as a string. | ||
+ | |||
+ | ==substr== | ||
+ | :Alias of <code>mid()</code> | ||
+ | |||
+ | ==substring== | ||
+ | :Alias of <code>mid()</code> | ||
+ | |||
+ | ==title== | ||
+ | :Syntax | ||
+ | ::<code>''string'' title(''string'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the <code>value</code> but in its title case format (each word starts with a capitalized letter). | ||
+ | :Examples | ||
+ | ::<code>lower("Hello there world")</code> outputs <code>Hello There World</code> | ||
+ | |||
+ | ==upper== | ||
+ | :Syntax | ||
+ | ::<code>''string'' upper(''string'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the <code>value</code> but with all upper case letters. | ||
+ | :Examples | ||
+ | ::<code>upper("Hello World")</code> outputs <code>HELLO WORLD</code> | ||
+ | |||
+ | ==text== | ||
+ | :Alias of <code>string()</code> | ||
+ | |||
+ | ==trim== | ||
+ | :Syntax | ||
+ | ::<code>"string" trim("string" value)</code> | ||
+ | :Returns | ||
+ | ::Returns the <code>value</code> with leading and trailing spaces removed | ||
+ | :Examples | ||
+ | ::<code>trim(" Hello World ")</code> outputs <code>Hello World</code> | ||
+ | |||
+ | ==trimLeft== | ||
+ | :Syntax | ||
+ | ::<code>"string" trimLeft("string" value)</code> | ||
+ | :Returns | ||
+ | ::Returns the <code>value</code> with leading spaces removed | ||
+ | :Examples | ||
+ | ::<code>trimLeft(" Hello World ")</code> outputs <code>"Hello World "</code> | ||
+ | |||
+ | ==ltrim== | ||
+ | :Alias of <code>trimLeft()</code> | ||
+ | |||
+ | ==trimRight== | ||
+ | :Syntax | ||
+ | ::<code>"string" trimRight("string" value)</code> | ||
+ | :Returns | ||
+ | ::Returns the <code>value</code> with trailing spaces removed | ||
+ | :Examples | ||
+ | ::<code>trimRight(" Hello World ")</code> outputs <code>" Hello World"</code> | ||
+ | |||
+ | ==rtrim== | ||
+ | :Alias of <code>trimRight()</code> | ||
+ | |||
+ | ==urlEncode== | ||
+ | :Syntax | ||
+ | ::<code>''string'' urlEncode(''dynamic'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns a string with all characters other than <code>a-z A-Z 0-9 . - * _ +</code> converted to percent encoding for use in a URL | ||
+ | :Examples | ||
+ | ::<code>urlEncode("John's iPhone 8+")</code> outputs <code>"John%27s%20iPhone%208+"</code> | ||
+ | ::<code><nowiki>"http://webcore.co/sample?device={urlEncode($currentEventDevice)}&attribute={urlEncode($currentEventAttribute)}&value={urlEncode($currentEventValue)}"</nowiki></code> ensures that the generated URL is valid even if the event information includes spaces, & signs, or other problematic characters. | ||
+ | |||
+ | ==encodeURIComponent== | ||
+ | :Alias of <code>urlEncode()</code> | ||
+ | |||
+ | =Numeric functions= | ||
+ | |||
+ | ==avg== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' avg(''decimal'' value1, ''decimal'' value2[, .., ''decimal'' valueN])</code> | ||
+ | :Returns | ||
+ | ::Returns the mean average of all the values provided. | ||
+ | |||
+ | ==abs== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' abs(''decimal'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the absolute value of the argument (e.g., remove negative sign for negative values). | ||
+ | |||
+ | ==ceil== | ||
+ | :Syntax | ||
+ | ::<code>''integer'' ceil(''decimal'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the immediately higher integer, equivalent to rounding the decimal away from zero. | ||
+ | :Examples | ||
+ | ::<code>ceil(5.6)</code> outputs <code>6</code> | ||
+ | ::<code>ceil(-5.6)</code> outputs <code>-6</code> | ||
+ | |||
+ | ==ceiling== | ||
+ | :Alias of <code>ceil</code> | ||
+ | |||
+ | ==decimal== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' decimal(''dynamic'' value)</code> | ||
+ | :Returns | ||
+ | ::Converts <code>value</code> into a decimal. Returns <code>0</code> if <code>value</code> is not numeric. | ||
+ | |||
+ | ==float== | ||
+ | :Alias of <code>decimal</code> | ||
+ | |||
+ | ==floor== | ||
+ | :Syntax | ||
+ | ::<code>''integer'' ceil(''decimal'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the integer part of a decimal, equivalent to rounding the decimal towards zero. | ||
+ | :Examples | ||
+ | ::<code>floor(5.6)</code> outputs <code>5</code> | ||
+ | ::<code>floor(-5.6)</code> outputs <code>-5</code> | ||
+ | |||
+ | ==max== | ||
+ | :Syntax | ||
+ | ::<code>''dynamic'' max(''dynamic'' value1, ''dynamic'' value2[, .., ''dynamic'' valueN])</code> | ||
+ | :Returns | ||
+ | ::Returns the maximum of all the values provided. Note: this function works with both numbers and strings. | ||
+ | |||
+ | ==median== | ||
+ | :Syntax | ||
+ | ::<code>''dynamic'' median(''dynamic'' value1, ''dynamic'' value2[, .., ''dynamic'' valueN])</code> | ||
+ | :Returns | ||
+ | ::Returns the median average of all the values provided. Note: this function works with both numbers and strings. | ||
+ | |||
+ | ==min== | ||
+ | :Syntax | ||
+ | ::<code>''dynamic'' min(''dynamic'' value1, ''dynamic'' value2[, .., ''dynamic'' valueN])</code> | ||
+ | :Returns | ||
+ | ::Returns the minimum of all the values provided. Note: this function works with both numbers and strings. | ||
+ | |||
+ | ==number== | ||
+ | :Alias of <code>decimal</code> | ||
+ | |||
+ | ==power== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' power(''decimal'' value, ''decimal'' exponent)</code> | ||
+ | :Returns | ||
+ | ::Returns the <code>value</code> at the power of <code>exponent</code> | ||
+ | |||
+ | ==round== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' round(''decimal'' value[, ''integer'' precision = 0])</code> | ||
+ | :Arguments | ||
+ | ::<code>precision</code> - the number of decimal places to be retained. If not provided, defaults to <code>0</code> | ||
+ | :Returns | ||
+ | ::Returns the rounded <code>value</code> with <code>precision</code> decimal places. | ||
+ | |||
+ | ==sqr== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' sqr(''decimal'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the squared <code>value</code>, equivalent to <code>value</code> multiplied by itself. | ||
+ | |||
+ | ==sqrt== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' sqrt(''decimal'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the square root of <code>value</code>. | ||
+ | |||
+ | ==stdev== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' stdev(''decimal'' value1, ''decimal'' value2[, .., ''decimal'' valueN])</code> | ||
+ | :Returns | ||
+ | ::Returns the standard deviation of all the values provided. | ||
+ | |||
+ | ==sum== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' sum(''decimal'' value1, ''decimal'' value2[, .., ''decimal'' valueN])</code> | ||
+ | :Returns | ||
+ | ::Returns the sum of sum of all the values provided. | ||
+ | |||
+ | ==variance== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' variance(''decimal'' value1, ''decimal'' value2[, .., ''decimal'' valueN])</code> | ||
+ | :Returns | ||
+ | ::Returns the variance of all the values provided. | ||
+ | |||
+ | =[[Variable_data_types#Boolean|Boolean]] functions= | ||
+ | |||
+ | ==bool== | ||
+ | :Syntax | ||
+ | ::<code>bool(''dynamic'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the truth value of the input. Accepts anything as input and will return true if <code>value</code> is either a non-zero number, a non-empty string (with some exceptions, see below), a non-empty device list, a non-empty date/time/datetime | ||
+ | |||
+ | ==boolean== | ||
+ | :This is an alias of [[Functions#bool|bool]] | ||
+ | |||
+ | ==eq== | ||
+ | :Syntax | ||
+ | ::<code>eq(''dynamic'' value1, ''dynamic'' value2)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>value1</code> is equivalent to <code>value2</code> | ||
+ | |||
+ | ==ge== | ||
+ | :Syntax | ||
+ | ::<code>ge(''dynamic'' value1, ''dynamic'' value2)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>value1</code> is greater than or equal to <code>value2</code> | ||
+ | |||
+ | ==gt== | ||
+ | :Syntax | ||
+ | ::<code>gt(''dynamic'' value1, ''dynamic'' value2)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>value1</code> is greater than <code>value2</code> | ||
+ | |||
+ | ==isBetween== | ||
+ | :Syntax | ||
+ | ::<code>isBetween(''dynamic'' value, ''dynamic'' startValue, ''dynamic'' endValue)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>value</code> is greater then or equal to <code>startValue</code> and less than or equal to <code>endValue</code> | ||
+ | |||
+ | ==isEmpty== | ||
+ | :Syntax | ||
+ | ::<code>isEmpty(''dynamic'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>value</code> is not set, an empty string, or zero | ||
+ | |||
+ | ==le== | ||
+ | :Syntax | ||
+ | ::<code>le(''dynamic'' value1, ''dynamic'' value2)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>value1</code> is less than or equal to <code>value2</code> | ||
+ | |||
+ | ==lt== | ||
+ | :Syntax | ||
+ | ::<code>lt(''dynamic'' value1, ''dynamic'' value2)</code> | ||
+ | :Returns | ||
+ | ::Returns true if <code>value1</code> is less than <code>value2</code> | ||
+ | |||
+ | ==not== | ||
+ | :Syntax | ||
+ | ::<code>not(''dynamic'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the negated truth state of <code>value</code>. This is the logical negation of <code>[[Functions#bool|bool]](''dynamic'' value)</code>. | ||
+ | |||
+ | =[[Variable_data_types#Date_and_Time|Date and time]] functions= | ||
+ | |||
+ | ==addDays== | ||
+ | :Syntax | ||
+ | ::<code>addDays(''datetime'' value, ''integer'' days)</code> | ||
+ | :Returns | ||
+ | ::Returns a datetime that is <code>days</code> days after the <code>value</code>. For negative values of <code>days</code>, it returns a datetime that is <code>days</code> days before <code>value</code>. | ||
+ | |||
+ | ==addHours== | ||
+ | :Syntax | ||
+ | ::<code>addHours(''datetime'' value, ''integer'' hours)</code> | ||
+ | :Returns | ||
+ | ::Returns a datetime that is <code>hours</code> hours after the <code>value</code>. For negative values of <code>hours</code>, it returns a datetime that is <code>hours</code> hours before <code>value</code>. | ||
+ | |||
+ | ==addMinutes== | ||
+ | :Syntax | ||
+ | ::<code>addMinutes(''datetime'' value, ''integer'' minutes)</code> | ||
+ | :Returns | ||
+ | ::Returns a datetime that is <code>minutes</code> minutes after the <code>value</code>. For negative values of <code>minutes</code>, it returns a datetime that is <code>minutes</code> minutes before <code>value</code>. | ||
+ | |||
+ | ==addSeconds== | ||
+ | :Syntax | ||
+ | ::<code>addSeconds(''datetime'' value, ''integer'' seconds)</code> | ||
+ | :Returns | ||
+ | ::Returns a datetime that is <code>seconds</code> seconds after the <code>value</code>. For negative values of <code>seconds</code>, it returns a datetime that is <code>seconds</code> seconds before <code>value</code>. | ||
+ | |||
+ | ==addWeeks== | ||
+ | :Syntax | ||
+ | ::<code>addWeeks(''datetime'' value, ''integer'' weeks)</code> | ||
+ | :Returns | ||
+ | ::Returns a datetime that is <code>weeks</code> weeks after the <code>value</code>. For negative values of <code>weeks</code>, it returns a datetime that is <code>weeks</code> weeks before <code>value</code>. | ||
+ | |||
+ | ==date== | ||
+ | :Syntax | ||
+ | ::<code>date(''datetime'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the date portion of <code>value</code> by stripping off time information. | ||
+ | |||
+ | ==datetime== | ||
+ | :Syntax | ||
+ | ::<code>''datetime'' datetime(''dynamic'' value)</code> | ||
+ | :Returns | ||
+ | ::Tries to convert any value into a datetime. Accepts strings in common date/time formats. | ||
+ | |||
+ | |||
+ | ==formatDuration== | ||
+ | :Syntax | ||
+ | ::<code>''string'' formatDuration(''datetime'' value[, ''boolean'' friendly = false[, ''string'' granularity = 's'[, ''boolean'' showAdverbs = false]]])</code> | ||
+ | :Arguments | ||
+ | ::<code>friendly</code> - <code>false</code> makes the output compact, in the form of <code>0d 00:00:00.000</code>, while <code>true</code> makes the output more human friendly, in the form of <code> 0 days, 0 hours, 0 minutes, and 0 seconds</code>. Defaults to <code>false</code>. | ||
+ | ::<code>granularity</code> - represents the smallest time unit to be output. One of <code>d</code> for days, <code>h</code> for hours, <code>m</code> for minutes, <code>s</code> for seconds, or <code>ms</code> for milliseconds. Any time unit below the selected granularity will not be output. Defaults to <code>s</code> | ||
+ | ::<code>showAdverbs</code> - only affects the friendly output, when <code>true</code> the words <code>in</code> (for future durations - positive input) or <code>ago</code> (for past durations - negative input) are prepended or appended respectively to the output | ||
+ | :Returns | ||
+ | ::Returns a string that represents the duration in a human readable format | ||
+ | :Examples | ||
+ | ::<code>formatDuration(12029)</code> will output <code>00:00:12</code> | ||
+ | ::<code>formatDuration(68493, true)</code> will output <code>1 minute and 8 seconds</code> | ||
+ | ::<code>formatDuration(68493, false, 'ms')</code> will output <code>00:01:08.493</code> | ||
+ | ::<code>formatDuration(68493, true, 'm', true)</code> will output <code>in 1 minute</code> | ||
+ | |||
+ | ==formatDateTime== | ||
+ | :Syntax | ||
+ | ::<code>formatDateTime(''datetime'' value, string)</code> | ||
+ | :Known Strings (caSe seNsiTivE) | ||
+ | ::G, y, M, d, h, H, m, s, S, E, D, F, w, W, a, k, K, z | ||
+ | :Examples | ||
+ | |||
+ | ----- | ||
+ | |||
+ | {| class="mw-datatable" | ||
+ | |- | ||
+ | ! rowspan="2" | Meaning | ||
+ | ! rowspan="2" | String | ||
+ | ! rowspan="2" | Sample Code | ||
+ | ! rowspan="2" | Sample<br>Output | ||
+ | ! rowspan="2" | Format | ||
+ | ! rowspan="2" | Range | ||
+ | ! rowspan="2" | Notes | ||
+ | |- | ||
+ | ! | ||
+ | |- | ||
+ | | Era | ||
+ | | <code>G</code> | ||
+ | | <code>formatDateTime($now, "G")</code> | ||
+ | | <code>AD</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | <code>BC? - AD</code> | ||
+ | | anno Domini | ||
+ | |- | ||
+ | | Year | ||
+ | | <code>y</code> | ||
+ | | <code>formatDateTime($now, "y")</code> | ||
+ | | <code>1992</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1970? - 2???</code> | ||
+ | | Range needs confirmation | ||
+ | |- | ||
+ | | Year (last 2 digits) | ||
+ | | <code>yy</code> | ||
+ | | <code>formatDateTime($now, "yy")</code> | ||
+ | | <code>92</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1970? - 2???</code> | ||
+ | | Range needs confirmation | ||
+ | |- | ||
+ | | Month (integer) | ||
+ | | <code>M</code> | ||
+ | | <code>formatDateTime($now, "M")</code> | ||
+ | | <code>3</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 12</code> | ||
+ | | | ||
+ | |- | ||
+ | | Month (padded) | ||
+ | | <code>MM</code> | ||
+ | | <code>formatDateTime($now, "MM")</code> | ||
+ | | <code>03</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>01 - 12</code> | ||
+ | | | ||
+ | |- | ||
+ | | Month (abbr.) | ||
+ | | <code>MMM</code> | ||
+ | | <code>formatDateTime($now, "MMM")</code> | ||
+ | | <code>Mar</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | <code>Jan - Dec</code> | ||
+ | | 3 Letter abbreviation | ||
+ | |- | ||
+ | | Month | ||
+ | | <code>MMMM</code> | ||
+ | | <code>formatDateTime($now, "MMMM")</code> | ||
+ | | <code>March</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | <code>January - December</code> | ||
+ | | Full word | ||
+ | |- | ||
+ | | Day of Month | ||
+ | | <code>d</code> | ||
+ | | <code>formatDateTime($now, "d")</code> | ||
+ | | <code>6?</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 31</code> | ||
+ | | | ||
+ | |- | ||
+ | | Day of Month | ||
+ | | <code>dd</code> | ||
+ | | <code>formatDateTime($now, "dd")</code> | ||
+ | | <code>26</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>01 - 31</code> | ||
+ | | | ||
+ | |- | ||
+ | | Hour | ||
+ | | <code>h</code> | ||
+ | | <code>formatDateTime($now, "h")</code> | ||
+ | | <code>7</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 12</code> | ||
+ | | | ||
+ | |- | ||
+ | | Hour (padded) | ||
+ | | <code>hh</code> | ||
+ | | <code>formatDateTime($now, "hh")</code> | ||
+ | | <code>07</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>01 - 12</code> | ||
+ | | | ||
+ | |- | ||
+ | | Hour (Military) | ||
+ | | <code>H</code> | ||
+ | | <code>formatDateTime($now, "H")</code> | ||
+ | | <code>22</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>0 - 23</code> | ||
+ | | | ||
+ | |- | ||
+ | | Hour (Military padded) | ||
+ | | <code>HH</code> | ||
+ | | <code>formatDateTime($now, "HH")</code> | ||
+ | | <code>07</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>00 - 23</code> | ||
+ | | | ||
+ | |- | ||
+ | | Minute | ||
+ | | <code>m</code> | ||
+ | | <code>formatDateTime($now, "m")</code> | ||
+ | | <code>8</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>0 - 59</code> | ||
+ | | | ||
+ | |- | ||
+ | | Minute (padded) | ||
+ | | <code>mm</code> | ||
+ | | <code>formatDateTime($now, "mm")</code> | ||
+ | | <code>08</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>00? - 59</code> | ||
+ | | | ||
+ | |- | ||
+ | | Second | ||
+ | | <code>s</code> | ||
+ | | <code>formatDateTime($now, "s")</code> | ||
+ | | <code>8</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>0 - 59</code> | ||
+ | | | ||
+ | |- | ||
+ | | Second (padded) | ||
+ | | <code>ss</code> | ||
+ | | <code>formatDateTime($now, "ss")</code> | ||
+ | | <code>08</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>00? - 59</code> | ||
+ | | "00" needs confirmation | ||
+ | |- | ||
+ | | Millisecond | ||
+ | | <code>S</code> | ||
+ | | <code>formatDateTime($now, "S")</code> | ||
+ | | <code>42</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>0 - 999</code> | ||
+ | | | ||
+ | |- | ||
+ | | Millisecond (padded) | ||
+ | | <code>SSS</code> | ||
+ | | <code>formatDateTime($now, "SSS")</code> | ||
+ | | <code>042</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>000? - 999</code> | ||
+ | | Good luck trying to capture "000" | ||
+ | |- | ||
+ | | Day of Week (abbr.) | ||
+ | | <code>E</code> | ||
+ | | <code>formatDateTime($now, "E")</code> | ||
+ | | <code>Sat</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | <code>Wed - Tue</code> | ||
+ | | | ||
+ | |- | ||
+ | | Day of Week | ||
+ | | <code>EEEE</code> | ||
+ | | <code>formatDateTime($now, "EEEE")</code> | ||
+ | | <code>Saturday</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | <code>Friday - Thursday</code> | ||
+ | | | ||
+ | |- | ||
+ | | Day of Year | ||
+ | | <code>D</code> | ||
+ | | <code>formatDateTime($now, "D")</code> | ||
+ | | <code>362</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 366</code> | ||
+ | | | ||
+ | |- | ||
+ | | Day of Week in Month | ||
+ | | <code>F</code> | ||
+ | | <code>formatDateTime($now, "F")</code> | ||
+ | | <code>3</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 5?</code> | ||
+ | | IE: 3rd Mon in May | ||
+ | |- | ||
+ | | Week in Year | ||
+ | | <code>w</code> | ||
+ | | <code>formatDateTime($now, "w")</code> | ||
+ | | <code>51</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 54?</code> | ||
+ | | "54" needs confirmation | ||
+ | |- | ||
+ | | Week in Month | ||
+ | | <code>W</code> | ||
+ | | <code>formatDateTime($now, "W")</code> | ||
+ | | <code>2</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 6?</code> | ||
+ | | "6" needs confirmation | ||
+ | |- | ||
+ | | AM/PM | ||
+ | | <code>a</code> | ||
+ | | <code>formatDateTime($now, "a")</code> | ||
+ | | <code>PM</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | <code>AM - PM</code> | ||
+ | | | ||
+ | |- | ||
+ | | Hour (alt version) | ||
+ | | <code>K</code> | ||
+ | | <code>formatDateTime($now, "K")</code> | ||
+ | | <code>7</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>0 - 11</code> | ||
+ | | | ||
+ | |- | ||
+ | | Hour (alt Military) | ||
+ | | <code>k</code> | ||
+ | | <code>formatDateTime($now, "k")</code> | ||
+ | | <code>24</code> | ||
+ | | Integer | ||
+ | | style="text-align:center;" | <code>1 - 24</code> | ||
+ | | | ||
+ | |- | ||
+ | | Time Zone (abbr.) | ||
+ | | <code>z</code> | ||
+ | | <code>formatDateTime($now, "z")</code> | ||
+ | | <code>EDT</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | ''Various'' | ||
+ | | | ||
+ | |- | ||
+ | | Time Zone | ||
+ | | <code>zzzz</code> | ||
+ | | <code>formatDateTime($now, "zzzz")</code> | ||
+ | | <code>Eastern<br>Daylight<br>Time</code> | ||
+ | | String | ||
+ | | style="text-align:center;" | ''Various'' | ||
+ | | Some locations cycle<br>twice a year | ||
+ | |- | ||
+ | | | ||
+ | |} | ||
+ | |||
+ | ---- | ||
+ | |||
+ | Here are a few combined examples: | ||
+ | |||
+ | {| class="mw-datatable" | ||
+ | |- | ||
+ | ! Sample Code | ||
+ | ! Sample Output | ||
+ | ! Notes | ||
+ | |- | ||
+ | | <code>formatDateTime($now, "H:m")</code> | ||
+ | | <code>23:55</code> | ||
+ | | | ||
+ | |- | ||
+ | | <code>formatDateTime($now, "h:mm a")</code> | ||
+ | | <code>8:01 PM</code> | ||
+ | | | ||
+ | |- | ||
+ | | <code>formatDateTime($now, "EEEE, MMM d, yy")</code> | ||
+ | | <code>Saturday, Mar 21, 20</code> | ||
+ | | | ||
+ | |- | ||
+ | | <code>formatDateTime("August 9, 1995", "EEEE")</code> | ||
+ | | <code>Wednesday</code> | ||
+ | | Note that "datetime value" does not have to be <code>$now</code> | ||
+ | |- | ||
+ | | | ||
+ | |} | ||
+ | |||
+ | |||
+ | :formatDateTime reference - https://docs.oracle.com/javase/tutorial/i18n/format/simpleDateFormat.html | ||
+ | :(We are using the term "Strings" here... They call them "Symbols" on that page) | ||
+ | |||
+ | |||
+ | . | ||
+ | |||
+ | ==time== | ||
+ | :Syntax | ||
+ | ::<code>''time'' time(''datetime'' value)</code> | ||
+ | :Returns | ||
+ | ::Returns the time portion of <code>value</code> by stripping off date information. | ||
+ | |||
+ | =Weather related functions= | ||
+ | |||
+ | ==celsius== | ||
+ | :Syntax | ||
+ | ::<code>''decimal'' celsius(''decimal'' value)</code> | ||
+ | :Returns | ||
+ | ::Converts a temperature value from Fahrenheit to Celsius. | ||
− | = | + | ==dewPoint== |
− | + | :Syntax | |
− | : | + | ::<code>''decimal'' dewPoint(''decimal'' temperature, ''decimal'' relativeHumidity[, ''string'' scale = 'F'])</code> |
+ | :Parameters | ||
+ | ::<code>scale</code> - optional, one of <code>"C"</code> or <code>"F"</code>, corresponding to the temperature range used for <code>temperature</code>. The result will be provided in the same scale. If no scale is provided, the Fahrenheit scale will be used. | ||
+ | :Returns | ||
+ | ::Returns the due temperature for a given temperature and relative humidity | ||
− | = | + | ==fahrenheit== |
− | + | :Syntax | |
− | : | + | ::<code>''decimal'' fahrenheit(''decimal'' value)</code> |
− | + | :Returns | |
− | : | + | ::Converts a temperature value from Celsius to Fahrenheit. |
− | |||
− | : | ||
− | |||
− | : | ||
− | |||
− | |||
− | = | + | ==convertTemperatureIfNeeded== |
− | + | :Syntax | |
− | : | + | ::<code>''decimal'' convertTemperatureIfNeeded(''decimal'' value, ''string'' scaleOfValue)</code> |
− | + | :Parameters | |
− | : | + | ::<code>value</code> - the numeric temperature value in units specified by the <code>scaleOfValue</code> parameter |
− | + | ::<code>scaleOfValue</code> - one of <code>"C"</code> or <code>"F"</code>, corresponding to the known unit of the value parameter | |
− | : | + | :Returns |
− | + | ::Converts the temperature value from Celsius to Fahrenheit or vice versa if the scale does not match the location's temperature scale (see <code>$temperatureScale</code>). If the provided unit matches the location's temperature scale the value is returned as-is. | |
− | |||
− | |||
− | |||
− | |||
− | : | ||
− | |||
− | : | ||
− | |||
− | :/ | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | : | ||
− | |||
− | :// | ||
− | |||
− | |||
− | |||
− | : | ||
− | |||
− | : | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | = Dynamic = | + | = [[Variable_data_types#Dynamic|Dynamic]] = |
;if(condition, valueIfTrue, valueIfFalse) | ;if(condition, valueIfTrue, valueIfFalse) | ||
:evaluates a boolean and returns value1 if true, or value2 otherwise | :evaluates a boolean and returns value1 if true, or value2 otherwise | ||
Line 95: | Line 784: | ||
:returns the previous value of the attribute | :returns the previous value of the attribute | ||
− | = Integers = | + | = [[Variable_data_types#Number_.28Integer.29|Integers]] = |
− | ;age([ | + | ;age([device﹕attribute]) |
:returns the number of milliseconds an attribute had the current value | :returns the number of milliseconds an attribute had the current value | ||
;count(values) | ;count(values) | ||
Line 104: | Line 793: | ||
;integer(decimal or string) | ;integer(decimal or string) | ||
:converts a decimal value to it's integer value | :converts a decimal value to it's integer value | ||
− | ;newer([ | + | ;newer([device﹕attribute],[...], [device﹕attribute], threshold) |
:returns the number of devices whose attribute had the current value for less than the specified number of milliseconds | :returns the number of devices whose attribute had the current value for less than the specified number of milliseconds | ||
− | ;older([ | + | ;older([device﹕attribute],[...], [device﹕attribute], threshold) |
:returns the number of devices whose attribute had the current value for more than the specified number of milliseconds | :returns the number of devices whose attribute had the current value for more than the specified number of milliseconds | ||
− | ;previousAge([ | + | ;previousAge([device﹕attribute]) |
− | :returns the number of milliseconds an attribute | + | :returns the number of milliseconds that have elapsed since an attribute changed to the previous value. If there is no previous value recorded returns <code>604800000</code>, which corresponds to 7 days. |
− | + | :Use <code>previousAge([device﹕attribute]) - age([device﹕attribute])</code> to determine the length of time that the device attribute had the previous value. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | : | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | = Time = | + | = [[Variable_data_types#Time|Time]] = |
;time(value) | ;time(value) | ||
:returns the value as a time type | :returns the value as a time type |
Latest revision as of 04:14, 23 March 2020
Contents
[hide]- 1 String functions
- 1.1 concat
- 1.2 contains
- 1.3 endsWith
- 1.4 format
- 1.5 indexOf
- 1.6 json
- 1.7 lastIndexOf
- 1.8 left
- 1.9 lower
- 1.10 mid
- 1.11 random
- 1.12 replace
- 1.13 right
- 1.14 startsWith
- 1.15 string
- 1.16 substr
- 1.17 substring
- 1.18 title
- 1.19 upper
- 1.20 text
- 1.21 trim
- 1.22 trimLeft
- 1.23 ltrim
- 1.24 trimRight
- 1.25 rtrim
- 1.26 urlEncode
- 1.27 encodeURIComponent
- 2 Numeric functions
- 3 Boolean functions
- 4 Date and time functions
- 5 Weather related functions
- 6 Dynamic
- 7 Integers
- 8 Time
Functions are extensions to expressions that allow data processing and conversion. Here is a list of all defined functions
String functions
concat
- Syntax
string concat(dynamic value1, dynamic value2[, .., dynamic valueN])
- Returns
- Returns a string that is the concatenation of all the supplied values. This function accepts two or more input values.
contains
- Syntax
boolean contains(string haystack, string needle)
- Returns
- Returns true if the
needle
is found anywhere in thehaystack
- Returns true if the
endsWith
- Syntax
boolean endsWith(string haystack, string needle)
- Returns
- Returns true if
haystack
ends with theneedle
- Returns true if
format
- Syntax
string format(string formatString[, dynamic value1[, .., dynamic valueN]])
- Returns
- Returns a string that is built based on the
formatString
with arguments replaced by their corresponding values. Follows the java syntax forprintf()
. See a quick reference here, or a more detailed reference Reference here. - Each % in the format string represents an argument and corresponds to a value (in order of appearance) in the value list. Each argument can have formatting settings, according to the reference provided.
- Returns a string that is built based on the
- Example
format('The temperature outside is %.2f degrees Fahrenheit', [Temp sensor:temperature])
outputsThe temperature outside is 71.26 degrees Fahrenheit
- The
%.2f
translates to "format asf
loat and use.2
decimal places.
indexOf
- Syntax
integer indexOf(string haystack, string needle)
- Returns
- Returns the character index of the first occurrence of
needle
insidehaystack
- Returns the character index of the first occurrence of
- Examples
indexOf("hello world", 'l')
outputs2
json
- Syntax
string json(dynamic value[, "boolean" pretty])
- Returns
- Returns the JSON representation of the provided value. If the pretty parameter is true, indentation is added to improve human readability
- Examples
json(true)
outputs"true"
json(123)
outputs"123"
json('Nicole "Nikki" Sawyer')
outputs""Nicole \"Nikki\" Sawyer""
json(myStringList, true)
outputs with pretty formatting"{
"name": "Jaime",
"present": true
}"
json(myDeviceList)
outputs"[":97e051eb6fea489fa7cf1aaa4cb7c171:",":73d68350942e4555a8c47c36f558681e:"]"
since device variables are internally a list of device IDs"\{"device": {json($currentEventDevice)}, "rooms": \[ {json(activeRoom)}, "Basement" \] \}"
building JSON by hand in a webCoRE expression requires any{}[]
characters in the JSON to be escaped with a backslash and all dynamic values must use thejson()
function to safely represent the value
lastIndexOf
- Syntax
integer lastIndexOf(string haystack, string needle)
- Returns
- Returns the character index of the last occurrence of
needle
insidehaystack
- Returns the character index of the last occurrence of
- Examples
lastIndexOf("hello world", 'l')
outputs9
left
- Syntax
string left(string value, integer length)
- Returns
- Returns the first
length
characters invalue
- Returns the first
- Examples
left("hello world", 2)
outputshe
lower
- Syntax
string lower(string value)
- Returns
- Returns the
value
but with all lower case letters.
- Returns the
- Examples
lower("Hello World")
outputshello world
mid
- Syntax
string mid(string value, integer start[, integer count = remaining])
- Arguments
start
- provides the 0-based index of the first character to copy. Ifstart
is negative, the counting starts from the end ofvalue
.count
- provides the number of characters to copy fromvalue
. If not provided, all of the remaining characters fromvalue
are returned, starting with character numberstart
. Ifcount
is negative, prior characters are returned.
- Returns
- Returns a substring of
value
,count
characters long, starting at character numberstart
. Note that the first character in any string has index 0.
- Returns a substring of
- Examples
mid("Hello World", 2, 3)
outputsllo
mid("Hello World", 2)
outputsllo World
mid("Hello World", -5, 2)
outputsWo
mid("Hello World", -1, -3)
outputsorl
random
- Syntax
dynamic random([integer range | dynamic value1, dynamic value2[, .., dynamic valueN]])
- Arguments
range
- an integer number representing a rangevalue1
..valueN
- any kind of arguments, one will be randomly returned
- Returns
- Returns a random decimal number between
0
and1
if no arguments are provided, or a number between0
andrange
(inclusive) if a single argument is provided, or a randomly selected argument if two or more arguments are provided.
- Returns a random decimal number between
- Examples
random()
outputs0.483
(random decimal)random(20)
outputs6
(random integer)random("Hello World", "Good morning", "Hello", "Hi")
outputsHello
(randomly selected value)
- Tips
- To output a random integer between 5 and 20 use
(5 + random(15))
- To output a random integer between -5 and 20 use
(-5 + random(25))
- To output a random integer between 5 and 20 use
replace
- Syntax
string replace(string haystack, string needle1, string replacement1[, .., string needleN, string replacementN])
- Returns
- Replaces all the occurrences of
needle
insidehaystack
with its respectivereplacement
. Multiple pairs ofneedle
/replacement
can be provided in one function call.
- Replaces all the occurrences of
- Regular expressions
- Needles support regular expressions when their value starts and ends with a
/
. For example,'/(\s)/'
will match all spaces.
- Needles support regular expressions when their value starts and ends with a
- Examples
replace("Hello World", 'World', 'Earth')
outputsHello Earth
replace("Hello World", 'World', 'Earth', 'Hello', 'Hi')
outputsHi Earth
replace("Hello World", 'World', 'Earth', 'Earth', 'Planet')
outputsHello Planet
right
- Syntax
string right(string value, integer length)
- Returns
- Returns the last
length
characters invalue
- Returns the last
- Examples
right("hello world", 4)
outputsorld
startsWith
- Syntax
boolean startsWith(string haystack, string needle)
- Returns
- Returns true if
haystack
starts with theneedle
- Returns true if
string
- Syntax
string string(dynamic value)
- Returns
- Returns
value
as a string.
- Returns
substr
- Alias of
mid()
substring
- Alias of
mid()
title
- Syntax
string title(string value)
- Returns
- Returns the
value
but in its title case format (each word starts with a capitalized letter).
- Returns the
- Examples
lower("Hello there world")
outputsHello There World
upper
- Syntax
string upper(string value)
- Returns
- Returns the
value
but with all upper case letters.
- Returns the
- Examples
upper("Hello World")
outputsHELLO WORLD
text
- Alias of
string()
trim
- Syntax
"string" trim("string" value)
- Returns
- Returns the
value
with leading and trailing spaces removed
- Returns the
- Examples
trim(" Hello World ")
outputsHello World
trimLeft
- Syntax
"string" trimLeft("string" value)
- Returns
- Returns the
value
with leading spaces removed
- Returns the
- Examples
trimLeft(" Hello World ")
outputs"Hello World "
ltrim
- Alias of
trimLeft()
trimRight
- Syntax
"string" trimRight("string" value)
- Returns
- Returns the
value
with trailing spaces removed
- Returns the
- Examples
trimRight(" Hello World ")
outputs" Hello World"
rtrim
- Alias of
trimRight()
urlEncode
- Syntax
string urlEncode(dynamic value)
- Returns
- Returns a string with all characters other than
a-z A-Z 0-9 . - * _ +
converted to percent encoding for use in a URL
- Returns a string with all characters other than
- Examples
urlEncode("John's iPhone 8+")
outputs"John%27s%20iPhone%208+"
"http://webcore.co/sample?device={urlEncode($currentEventDevice)}&attribute={urlEncode($currentEventAttribute)}&value={urlEncode($currentEventValue)}"
ensures that the generated URL is valid even if the event information includes spaces, & signs, or other problematic characters.
encodeURIComponent
- Alias of
urlEncode()
Numeric functions
avg
- Syntax
decimal avg(decimal value1, decimal value2[, .., decimal valueN])
- Returns
- Returns the mean average of all the values provided.
abs
- Syntax
decimal abs(decimal value)
- Returns
- Returns the absolute value of the argument (e.g., remove negative sign for negative values).
ceil
- Syntax
integer ceil(decimal value)
- Returns
- Returns the immediately higher integer, equivalent to rounding the decimal away from zero.
- Examples
ceil(5.6)
outputs6
ceil(-5.6)
outputs-6
ceiling
- Alias of
ceil
decimal
- Syntax
decimal decimal(dynamic value)
- Returns
- Converts
value
into a decimal. Returns0
ifvalue
is not numeric.
- Converts
float
- Alias of
decimal
floor
- Syntax
integer ceil(decimal value)
- Returns
- Returns the integer part of a decimal, equivalent to rounding the decimal towards zero.
- Examples
floor(5.6)
outputs5
floor(-5.6)
outputs-5
max
- Syntax
dynamic max(dynamic value1, dynamic value2[, .., dynamic valueN])
- Returns
- Returns the maximum of all the values provided. Note: this function works with both numbers and strings.
median
- Syntax
dynamic median(dynamic value1, dynamic value2[, .., dynamic valueN])
- Returns
- Returns the median average of all the values provided. Note: this function works with both numbers and strings.
min
- Syntax
dynamic min(dynamic value1, dynamic value2[, .., dynamic valueN])
- Returns
- Returns the minimum of all the values provided. Note: this function works with both numbers and strings.
number
- Alias of
decimal
power
- Syntax
decimal power(decimal value, decimal exponent)
- Returns
- Returns the
value
at the power ofexponent
- Returns the
round
- Syntax
decimal round(decimal value[, integer precision = 0])
- Arguments
precision
- the number of decimal places to be retained. If not provided, defaults to0
- Returns
- Returns the rounded
value
withprecision
decimal places.
- Returns the rounded
sqr
- Syntax
decimal sqr(decimal value)
- Returns
- Returns the squared
value
, equivalent tovalue
multiplied by itself.
- Returns the squared
sqrt
- Syntax
decimal sqrt(decimal value)
- Returns
- Returns the square root of
value
.
- Returns the square root of
stdev
- Syntax
decimal stdev(decimal value1, decimal value2[, .., decimal valueN])
- Returns
- Returns the standard deviation of all the values provided.
sum
- Syntax
decimal sum(decimal value1, decimal value2[, .., decimal valueN])
- Returns
- Returns the sum of sum of all the values provided.
variance
- Syntax
decimal variance(decimal value1, decimal value2[, .., decimal valueN])
- Returns
- Returns the variance of all the values provided.
Boolean functions
bool
- Syntax
bool(dynamic value)
- Returns
- Returns the truth value of the input. Accepts anything as input and will return true if
value
is either a non-zero number, a non-empty string (with some exceptions, see below), a non-empty device list, a non-empty date/time/datetime
- Returns the truth value of the input. Accepts anything as input and will return true if
boolean
- This is an alias of bool
eq
- Syntax
eq(dynamic value1, dynamic value2)
- Returns
- Returns true if
value1
is equivalent tovalue2
- Returns true if
ge
- Syntax
ge(dynamic value1, dynamic value2)
- Returns
- Returns true if
value1
is greater than or equal tovalue2
- Returns true if
gt
- Syntax
gt(dynamic value1, dynamic value2)
- Returns
- Returns true if
value1
is greater thanvalue2
- Returns true if
isBetween
- Syntax
isBetween(dynamic value, dynamic startValue, dynamic endValue)
- Returns
- Returns true if
value
is greater then or equal tostartValue
and less than or equal toendValue
- Returns true if
isEmpty
- Syntax
isEmpty(dynamic value)
- Returns
- Returns true if
value
is not set, an empty string, or zero
- Returns true if
le
- Syntax
le(dynamic value1, dynamic value2)
- Returns
- Returns true if
value1
is less than or equal tovalue2
- Returns true if
lt
- Syntax
lt(dynamic value1, dynamic value2)
- Returns
- Returns true if
value1
is less thanvalue2
- Returns true if
not
- Syntax
not(dynamic value)
- Returns
- Returns the negated truth state of
value
. This is the logical negation ofbool(dynamic value)
.
- Returns the negated truth state of
Date and time functions
addDays
- Syntax
addDays(datetime value, integer days)
- Returns
- Returns a datetime that is
days
days after thevalue
. For negative values ofdays
, it returns a datetime that isdays
days beforevalue
.
- Returns a datetime that is
addHours
- Syntax
addHours(datetime value, integer hours)
- Returns
- Returns a datetime that is
hours
hours after thevalue
. For negative values ofhours
, it returns a datetime that ishours
hours beforevalue
.
- Returns a datetime that is
addMinutes
- Syntax
addMinutes(datetime value, integer minutes)
- Returns
- Returns a datetime that is
minutes
minutes after thevalue
. For negative values ofminutes
, it returns a datetime that isminutes
minutes beforevalue
.
- Returns a datetime that is
addSeconds
- Syntax
addSeconds(datetime value, integer seconds)
- Returns
- Returns a datetime that is
seconds
seconds after thevalue
. For negative values ofseconds
, it returns a datetime that isseconds
seconds beforevalue
.
- Returns a datetime that is
addWeeks
- Syntax
addWeeks(datetime value, integer weeks)
- Returns
- Returns a datetime that is
weeks
weeks after thevalue
. For negative values ofweeks
, it returns a datetime that isweeks
weeks beforevalue
.
- Returns a datetime that is
date
- Syntax
date(datetime value)
- Returns
- Returns the date portion of
value
by stripping off time information.
- Returns the date portion of
datetime
- Syntax
datetime datetime(dynamic value)
- Returns
- Tries to convert any value into a datetime. Accepts strings in common date/time formats.
formatDuration
- Syntax
string formatDuration(datetime value[, boolean friendly = false[, string granularity = 's'[, boolean showAdverbs = false]]])
- Arguments
friendly
-false
makes the output compact, in the form of0d 00:00:00.000
, whiletrue
makes the output more human friendly, in the form of0 days, 0 hours, 0 minutes, and 0 seconds
. Defaults tofalse
.granularity
- represents the smallest time unit to be output. One ofd
for days,h
for hours,m
for minutes,s
for seconds, orms
for milliseconds. Any time unit below the selected granularity will not be output. Defaults tos
showAdverbs
- only affects the friendly output, whentrue
the wordsin
(for future durations - positive input) orago
(for past durations - negative input) are prepended or appended respectively to the output
- Returns
- Returns a string that represents the duration in a human readable format
- Examples
formatDuration(12029)
will output00:00:12
formatDuration(68493, true)
will output1 minute and 8 seconds
formatDuration(68493, false, 'ms')
will output00:01:08.493
formatDuration(68493, true, 'm', true)
will outputin 1 minute
formatDateTime
- Syntax
formatDateTime(datetime value, string)
- Known Strings (caSe seNsiTivE)
- G, y, M, d, h, H, m, s, S, E, D, F, w, W, a, k, K, z
- Examples
Meaning | String | Sample Code | Sample Output |
Format | Range | Notes |
---|---|---|---|---|---|---|
Era | G
|
formatDateTime($now, "G")
|
AD
|
String | BC? - AD
|
anno Domini |
Year | y
|
formatDateTime($now, "y")
|
1992
|
Integer | 1970? - 2???
|
Range needs confirmation |
Year (last 2 digits) | yy
|
formatDateTime($now, "yy")
|
92
|
Integer | 1970? - 2???
|
Range needs confirmation |
Month (integer) | M
|
formatDateTime($now, "M")
|
3
|
Integer | 1 - 12
|
|
Month (padded) | MM
|
formatDateTime($now, "MM")
|
03
|
Integer | 01 - 12
|
|
Month (abbr.) | MMM
|
formatDateTime($now, "MMM")
|
Mar
|
String | Jan - Dec
|
3 Letter abbreviation |
Month | MMMM
|
formatDateTime($now, "MMMM")
|
March
|
String | January - December
|
Full word |
Day of Month | d
|
formatDateTime($now, "d")
|
6?
|
Integer | 1 - 31
|
|
Day of Month | dd
|
formatDateTime($now, "dd")
|
26
|
Integer | 01 - 31
|
|
Hour | h
|
formatDateTime($now, "h")
|
7
|
Integer | 1 - 12
|
|
Hour (padded) | hh
|
formatDateTime($now, "hh")
|
07
|
Integer | 01 - 12
|
|
Hour (Military) | H
|
formatDateTime($now, "H")
|
22
|
Integer | 0 - 23
|
|
Hour (Military padded) | HH
|
formatDateTime($now, "HH")
|
07
|
Integer | 00 - 23
|
|
Minute | m
|
formatDateTime($now, "m")
|
8
|
Integer | 0 - 59
|
|
Minute (padded) | mm
|
formatDateTime($now, "mm")
|
08
|
Integer | 00? - 59
|
|
Second | s
|
formatDateTime($now, "s")
|
8
|
Integer | 0 - 59
|
|
Second (padded) | ss
|
formatDateTime($now, "ss")
|
08
|
Integer | 00? - 59
|
"00" needs confirmation |
Millisecond | S
|
formatDateTime($now, "S")
|
42
|
Integer | 0 - 999
|
|
Millisecond (padded) | SSS
|
formatDateTime($now, "SSS")
|
042
|
Integer | 000? - 999
|
Good luck trying to capture "000" |
Day of Week (abbr.) | E
|
formatDateTime($now, "E")
|
Sat
|
String | Wed - Tue
|
|
Day of Week | EEEE
|
formatDateTime($now, "EEEE")
|
Saturday
|
String | Friday - Thursday
|
|
Day of Year | D
|
formatDateTime($now, "D")
|
362
|
Integer | 1 - 366
|
|
Day of Week in Month | F
|
formatDateTime($now, "F")
|
3
|
Integer | 1 - 5?
|
IE: 3rd Mon in May |
Week in Year | w
|
formatDateTime($now, "w")
|
51
|
Integer | 1 - 54?
|
"54" needs confirmation |
Week in Month | W
|
formatDateTime($now, "W")
|
2
|
Integer | 1 - 6?
|
"6" needs confirmation |
AM/PM | a
|
formatDateTime($now, "a")
|
PM
|
String | AM - PM
|
|
Hour (alt version) | K
|
formatDateTime($now, "K")
|
7
|
Integer | 0 - 11
|
|
Hour (alt Military) | k
|
formatDateTime($now, "k")
|
24
|
Integer | 1 - 24
|
|
Time Zone (abbr.) | z
|
formatDateTime($now, "z")
|
EDT
|
String | Various | |
Time Zone | zzzz
|
formatDateTime($now, "zzzz")
|
Eastern
|
String | Various | Some locations cycle twice a year |
Here are a few combined examples:
Sample Code | Sample Output | Notes |
---|---|---|
formatDateTime($now, "H:m")
|
23:55
|
|
formatDateTime($now, "h:mm a")
|
8:01 PM
|
|
formatDateTime($now, "EEEE, MMM d, yy")
|
Saturday, Mar 21, 20
|
|
formatDateTime("August 9, 1995", "EEEE")
|
Wednesday
|
Note that "datetime value" does not have to be $now
|
- formatDateTime reference - https://docs.oracle.com/javase/tutorial/i18n/format/simpleDateFormat.html
- (We are using the term "Strings" here... They call them "Symbols" on that page)
.
time
- Syntax
time time(datetime value)
- Returns
- Returns the time portion of
value
by stripping off date information.
- Returns the time portion of
celsius
- Syntax
decimal celsius(decimal value)
- Returns
- Converts a temperature value from Fahrenheit to Celsius.
dewPoint
- Syntax
decimal dewPoint(decimal temperature, decimal relativeHumidity[, string scale = 'F'])
- Parameters
scale
- optional, one of"C"
or"F"
, corresponding to the temperature range used fortemperature
. The result will be provided in the same scale. If no scale is provided, the Fahrenheit scale will be used.
- Returns
- Returns the due temperature for a given temperature and relative humidity
fahrenheit
- Syntax
decimal fahrenheit(decimal value)
- Returns
- Converts a temperature value from Celsius to Fahrenheit.
convertTemperatureIfNeeded
- Syntax
decimal convertTemperatureIfNeeded(decimal value, string scaleOfValue)
- Parameters
value
- the numeric temperature value in units specified by thescaleOfValue
parameterscaleOfValue
- one of"C"
or"F"
, corresponding to the known unit of the value parameter
- Returns
- Converts the temperature value from Celsius to Fahrenheit or vice versa if the scale does not match the location's temperature scale (see
$temperatureScale
). If the provided unit matches the location's temperature scale the value is returned as-is.
- Converts the temperature value from Celsius to Fahrenheit or vice versa if the scale does not match the location's temperature scale (see
Dynamic
- if(condition, valueIfTrue, valueIfFalse)
- evaluates a boolean and returns value1 if true, or value2 otherwise
- least(values)
- returns the value that is least found a series of numeric values
- most(values)
- returns the value that is most found a series of numeric values
- previousValue([device;attribute])
- returns the previous value of the attribute
Integers
- age([device﹕attribute])
- returns the number of milliseconds an attribute had the current value
- count(values)
- calculates the number of true/non-zero/non-empty items in a series of numeric values
- int()
- //todo
- integer(decimal or string)
- converts a decimal value to it's integer value
- newer([device﹕attribute],[...], [device﹕attribute], threshold)
- returns the number of devices whose attribute had the current value for less than the specified number of milliseconds
- older([device﹕attribute],[...], [device﹕attribute], threshold)
- returns the number of devices whose attribute had the current value for more than the specified number of milliseconds
- previousAge([device﹕attribute])
- returns the number of milliseconds that have elapsed since an attribute changed to the previous value. If there is no previous value recorded returns
604800000
, which corresponds to 7 days. - Use
previousAge([device﹕attribute]) - age([device﹕attribute])
to determine the length of time that the device attribute had the previous value.
Time
- time(value)
- returns the value as a time type
- addSeconds(dateTime, seconds)
- adds seconds to time, returns the value as a time type
- addMinutes(dateTime, minutes)
- adds minutes to time, returns the value as a time type
- addHours(dateTime, hours)
- adds hours to time, returns the value as a time type
- addDays(dateTime, days)
- adds days to time, returns the value as a time type
- addWeeks(dateTime, weeks)
- adds weeks to time, returns the value as a time type