/
To Int (int)

To Int (int)

Description

Converts a valid number string, a float number or a MAC address into an integer number. Note that float numbers are not rounded, so the result will be the integral part.

You can also extract an integer value from a json (json data type) using the Jq evaluation (jqeval) operation and convert it into integer type.

How does it work in the search window?

Select Create column in the search window toolbar, then select the To Int operation. You need to specify one argument:

Argument

Data type

Argument

Data type

String to convert / Number to convert / MAC to convert / Json to convert mandatory

string, float, mac, json

The data type of the values in the new column is integer.

Example 1

In the siem.logtrust.web.activity table, we want to divide the values of the bytesTransferred column by 2.5, and then transform the resulting float values into integer. First, use the Division (div, \) operation to get the results needed in a new column (BytesFloat). 

Then, add a new column using the To Int operation. The arguments needed are:

  • Number to convert BytesFloat column

 

Click Create column and you will see the following result:

Example 2

We have the following JSON string:

{"str": "hello", "int": 1, "float": 2.5, "boolean": true, "array": [1,2,3], "object": {"a": 5}}

And we want to extract the integer value in it in a new column and convert it to integer data type. To do it, the first step is transforming the string into a json data type column, and then using the Jq evaluation (jqeval) operation to extract the integer parts from the JSON objects.

Step 1: Transform the JSON string into json data type

We use the To json operation and enter the JSON string we want to use to get a column representing it in json data type.

 

Step 2: Extract the integer value from the JSON objects

Then, we use the Jq evaluation (jqeval) operation to extract the integer part of the JSON objects in a new column, in json data type. These are the required arguments:

  • jq -  Click the pencil icon and enter .int

  • json - json column

 

Step 3: Transform the integer values into integer data type

Finally, we use the To int operation to transform the integer representations in json data type into integer data type. 

How does it work in LINQ?

Use the operator select... as...  and add the operation syntax to create the new column. These are the valid formats of the To Int operation:

  • int(number_string)

  • int(float)

  • int(mac)

  • int(json_integer)

Example 1

You can copy the following LINQ script and try the first example explained above on the siem.logtrust.web.activity table. 

from siem.logtrust.web.activity select bytesTransferred \ 2.5 as BytesFloat, int(BytesFloat) as BytesInteger

Example 2

You can copy the following LINQ script and try the second example explained above on the siem.logtrust.web.activity table. 

from siem.logtrust.web.activity select jsonparse("{\"str\": \"hello\", \"int\": 1, \"float\": 2.5, \"boolean\": true, \"array\": [1,2,3], \"object\": {\"a\": 5}}") as json select jqeval(jqcompile(".int"), json) as jsonInt, int(jsonInt) as Integer