Understanding SPL syntax
The following sections describe the syntax used for the Splunk SPL commands. For additional information about using keywords, phrases, wildcards, and regular expressions, see Search command primer.
Required and optional arguments
SPL commands consist of required and optional arguments.
- Required arguments are shown in angle brackets < >.
- Optional arguments are enclosed in square brackets [ ].
Consider this command syntax:
bin [<bins-options>...] <field> [AS <newfield>]
The required argument is <field>
. To use this command, at a minimum you must specify bin <field>
.
The optional arguments are [<bins-options>...]
and [AS <newfield>]
.
User input arguments
Consider this command syntax:
replace (<wc-string> WITH <wc-string>)... [IN <field-list>]
The user input arguments are: <wc-string>
and <field-list>
. The argument <wc-string>
is an abbreviation for <wildcard-string> and indicates that the argument accepts a wildcard character in the string that you provide. See Wildcards in the Search Reference.
Repeating arguments
Some arguments can be specified multiple times. The syntax displays ellipsis ... to specify which part of an argument can be repeated. The ellipsis always appear immediately after the part of the syntax that you can repeat.
Consider this command:
convert [timeformat=string] (<convert-function> [AS <field>])...
The required argument is <convert-function>
, with an option to specify a field with the [AS <field>]
clause.
Notice the ellipsis at the end of the syntax, just after the close parenthesis. In this example, the syntax that is inside the parenthesis can be repeated <convert-function> [AS <field>]
.
In the following syntax, you can repeat the <bins-options>...
.
bin [<bins-options>...] <field> [AS <newfield>]
Grouped arguments
Sometimes the syntax must display arguments as a group to show that the set of arguments are used together. Parenthesis ( ) are used to group arguments.
For example in this syntax:
replace (<wc-string> WITH <wc-string>)... [IN <field-list>]
The grouped argument is (<wc-string> WITH <wc-string>)...
. This is a required set of arguments that you can repeat multiple times.
Keywords
Many commands use keywords with some of the arguments or options. Examples of keywords include:
- AS
- BY
- OVER
- WHERE
You can specify these keywords in uppercase or lowercase in your search. However, for readability, the syntax in the Splunk documentation uses uppercase on all keywords.
Quoted elements
If an element is in quotation marks, you must include that element in your search. The most common quoted elements are parenthesis.
Consider the syntax for the chart
command:
chart [<chart-options>] [agg=<stats-agg-term>] ( <stats-agg-term> | <sparkline-agg-term> | "("<eval-expression>")" )... [ BY <row-split> <column-split> ] | [ OVER <row-split> ] [BY <column-split>] ]
There are quotation marks on the parenthesis surrounding the <eval-expression>
. This means that you must enclose the <eval-expression>
in parenthesis in your search.
In the following search example, the <eval-expression>
is avg(size)/max(delay)
and is enclosed in parenthesis.
... | chart eval(avg(size)/max(delay)) AS ratio BY host user
Argument order
In the command syntax, the command arguments are presented in the order in which the arguments are meant to be used.
In the descriptions of the arguments, the Required arguments and Optional argument sections, the arguments are listed alphabetically. For each argument, there is a Syntax and Description. Additionally, for Optional arguments, there might be a Default.
Data types
The nomenclature used for the data types in SPL syntax are described in the following table.
Syntax | Data type | Notes |
---|---|---|
<bool> | boolean | Use true or false . Other variations are accepted. For example, for true you can also use 't', 'T', 'TRUE', 'yes', or the number one ( 1 ). For false you can also specify 'no', the number zero ( 0 ), and variations of the word false , similar to the variations of the word true .
|
<field> | A field name. You cannot specify a wild card for the field name. | See <wc-field>. |
<int> or <integer> | An integer that can be a positive or negative value. | Sometimes referred to as a "signed" integer. See <unsigned int>. |
<string> | string | See <wc-string>. |
<unsigned int> | unsigned integer | An unsigned integer must be positive value. Unsigned integers can be larger numbers than signed integers. |
<wc-field> | A field name or a partial name with a wildcard character to specify multiple, similarly named fields. | Use the asterisk ( * ) character as the wildcard character. |
<wc-string> | A string value or partial string value with a wildcard character. | Use the asterisk ( * ) character as the wildcard character. |
Logical operators
When a logical operator is included in the syntax of a command, you must always specify the operator in uppercase. Logical operators include:
- AND
- OR
- NOT
- XOR
The search
command evaluates operates logical operators in a different order of precedence than the eval
and where
commands.. To learn more about the order in which boolean expressions are evaluated, along with some examples, see
Boolean expressions with logical operators in the Search Manual.
To learn more about the the NOT operator, see Difference between NOT and != in the Search Manual.
BY clauses
A <by-clause> and a <split-by-clause> are not the same argument.
When you use a <by-clause>, one row is returned for each distinct value <by-clause> field. A <by-clause> displays each unique item in a separate row. Think of the <by-clause> as a grouping.
The <split-by-clause> displays each unique item in a separate column. Think of the <split-by-clause> as a splitting or dividing.
Wildcard characters ( * ) are not accepted in BY clauses.
Fields and wildcard fields
When the syntax contains <field>
you specify a field name from your events.
Consider this syntax:
bin [<bins-options>...] <field> [AS <newfield>]
The <field>
argument is required. You can specify that the field displays a different name in the search results by using the [AS <newfield>]
argument. This argument is optional.
For example, if the field is categoryId
and you want the field to be named CategoryID
in the output, you would specify:
categoryId AS CategoryID
The <wc-field>
argument indicates that you can use wild card characters when specifying field names. For example, if you have a set of fields that end with "log" you can specify *log
to return all of those fields.
If you use a wild card character in the middle of a value, especially as a wild card for punctuation, the results might be unpredictable.
Repeating expressions
With many commands you can specify multiple expressions. Some commands use a space between expressions, while other commands use a comma between expressions. In the syntax for a command you will see something like <field-list
to indicate that you can specify one or more expressions.
For example, the stats
command includes a <field-list
argument. The list of fields must be separated by commas:
sourcetype=access_* | stats count BY status, host
With the outlier
command, the <field-list
argument expects the field names to be space-separated:
...| outlier bytes clientip
See also
In the Search Manual:
Welcome to the Search Reference | How to use this manual |
This documentation applies to the following versions of Splunk® Enterprise: 7.0.0, 7.0.1, 7.0.2, 7.0.3, 7.0.4, 7.0.5, 7.0.6, 7.0.7, 7.0.8, 7.0.9, 7.0.10, 7.0.11, 7.0.13, 7.1.0, 7.1.1, 7.1.2, 7.1.3, 7.1.4, 7.1.5, 7.1.6, 7.1.7, 7.1.8, 7.1.9, 7.1.10, 7.2.0, 7.2.1, 7.2.2, 7.2.3, 7.2.4, 7.2.5, 7.2.6, 7.2.7, 7.2.8, 7.2.9, 7.2.10, 7.3.0, 7.3.1, 7.3.2, 7.3.3, 7.3.4, 7.3.5, 7.3.6, 7.3.7, 7.3.8, 7.3.9, 8.0.0, 8.0.1, 8.0.2, 8.0.3, 8.0.4, 8.0.5, 8.0.6, 8.0.7, 8.0.8, 8.0.9, 8.0.10, 8.1.0, 8.1.1, 8.1.3, 8.1.4, 8.1.5, 8.1.6, 8.1.7, 8.1.8, 8.1.9, 8.1.11, 8.1.13, 8.2.0, 8.2.1, 8.2.2, 8.2.3, 8.2.4, 8.2.5, 8.2.6, 8.2.7, 8.2.8, 8.2.9, 8.2.10, 8.2.11, 8.2.12, 9.0.0, 9.0.1, 9.0.2, 9.0.3, 9.0.4, 9.0.5, 9.0.6, 9.0.7, 9.0.8, 9.0.9, 9.0.10, 9.1.0, 9.1.1, 9.1.2, 9.1.3, 9.1.4, 9.1.5, 9.1.6, 9.1.7, 9.2.0, 9.2.1, 9.2.2, 9.2.3, 9.2.4, 9.3.0, 9.3.1, 9.3.2, 9.4.0, 8.1.10, 8.1.12, 8.1.14, 8.1.2
Feedback submitted, thanks!