'Pretty Prints' an XML field. This can be an expensive operation and you should usually do this after filtering your data (at the end of your query) This will prevent data that will be filtered out from being formatted. If the field does not contain valid XML, the unmodified input value is stored in the output field. If no field is specified the @rawstring will be formatted.
Parameter | Type | Required | Default | Description |
---|---|---|---|---|
as | string | optional[a] | The name of the field to store the output in. | |
field [b] | string | required | @rawstring | The name of the field to format. |
step | integer | optional[a] | 2 | The indentation in number of characters. |
strict | boolean | optional[a] | false | If set to true only valid XML input produce a value in the output field. By default invalid XML is copied to the output field unmodified. |
width | integer | optional[a] | 80 | The width (in number of characters) to fit the output input. |
[a] Optional parameters use their default value unless explicitly set |
Omitted Argument NamesThe argument name for
field
can be omitted; the following forms of this function are equivalent:logscalexml:prettyPrint("field")
and:
logscalexml:prettyPrint(field="field")
These examples show basic structure only; full examples are provided below.
xml:prettyPrint()
Examples
Format XML in the @rawstring field after filtering the data.
#type=SOAP
| account=123
| xml:prettyPrint()
Format XML in the field field payload to a max line length of 100 and indent by 4 spaces.
formattedXml := xml:prettyPrint(field=payload, step=4, width=100)
Only copy valid XML to the output field by setting
strict=true
. Here
the field formattedXml will not be created for
events with invalid XML in message.
formattedXml := xml:prettyPrint(field=message, strict=true)