Splunk Search

tonumber() not working

jedatt01
Builder

I have an extracted field that is alphanumeric and splunk is interpreting it as a string, obviously. But I am using rtrim to remove the alpha characters and leave only numeric characters. But as I confirmed with if(isstr()) splunk is still interpreting the field as a string. So, I tried to convert to number with tonumber() but results are coming back null. Any suggestions?

Tags (2)
1 Solution

Wilcooley
Path Finder

I don't suppose you could give an example of the field? That would help immensely. I'm guessing it's something like "100 kWH"?

Have you confirmed that eval xx=rtrim(Total_Energy,"kWH") results in something that looks like a number? Is there a space in your "kWH" that I can't see and is there a space between the number and the string? A trailing space might make the rtrim output look not like a number and would be hard to see.

rtrim seems kinda like an odd choice, though it seems like it should work. Personally I would have used a regular expression with replace:

replace(Total_Energy, "^(\d+)", "\1")

View solution in original post

Wilcooley
Path Finder

I don't suppose you could give an example of the field? That would help immensely. I'm guessing it's something like "100 kWH"?

Have you confirmed that eval xx=rtrim(Total_Energy,"kWH") results in something that looks like a number? Is there a space in your "kWH" that I can't see and is there a space between the number and the string? A trailing space might make the rtrim output look not like a number and would be hard to see.

rtrim seems kinda like an odd choice, though it seems like it should work. Personally I would have used a regular expression with replace:

replace(Total_Energy, "^(\d+)", "\1")

jedatt01
Builder

That was the problem. I was forgetting about the space before the kWH. this worked correctly
eval xx=rtrim(Total_Energy, " kWH")
Thanks!!

0 Karma

jedatt01
Builder

figured out a workaround from another post that converts my string to a number. Could there be a bug in tonumber()?

eval TE=strptime(rtrim(Total_Energy,"kWH"),"%s")

0 Karma
Got questions? Get answers!

Join the Splunk Community Slack to learn, troubleshoot, and make connections with fellow Splunk practitioners in real time!

Meet up IRL or virtually!

Join Splunk User Groups to connect and learn in-person by region or remotely by topic or industry.

Get Updates on the Splunk Community!

Announcing Modern Navigation: A New Era of Splunk User Experience

We are excited to introduce the Modern Navigation feature in the Splunk Platform, available to both cloud and ...

Modernize your Splunk Apps – Introducing Python 3.13 in Splunk

We are excited to announce that the upcoming releases of Splunk Enterprise 10.2.x and Splunk Cloud Platform ...

Step into “Hunt the Insider: An Splunk ES Premier Mystery” to catch a cybercriminal ...

After a whole week of being on call, you fell asleep on your keyboard, and you hit a sequence of buttons that ...