This browser is no longer supported.

Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.

Download Microsoft Edge More info about Internet Explorer and Microsoft Edge

Get a match for a regular expression from a source string.

Optionally, convert the extracted substring to the indicated type.

Syntax

extract( regex , captureGroup , source [ , typeLiteral ] )

Learn more about syntax conventions .

Parameters

Required Description The capture group to extract. 0 stands for the entire match, 1 for the value matched by the first '('parenthesis')' in the regular expression, and 2 or more for subsequent parentheses. source string The string to search. typeLiteral string If provided, the extracted substring is converted to this type. For example, typeof(long) .

Returns

If regex finds a match in source : the substring matched against the indicated capture group captureGroup , optionally converted to typeLiteral .

If there's no match, or the type conversion fails: null .

Examples

The example string Trace is searched for a definition for Duration . The match is converted to real , then multiplied it by a time constant ( 1s ) so that Duration is of type timespan . In this example, it's equal to 123.45 seconds:

| extend Trace="A=1, B=2, Duration=123.45, ..." | extend Duration = extract("Duration=([0-9.]+)", 1, Trace, typeof(real)) * time(1s)

This example is equivalent to substring(Text, 2, 4) :

extract("^.{2,2}(.{4,4})", 1, Text)