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
Get Updates on the Splunk Community!

Fun with Regular Expression - multiples of nine

Fun with Regular Expression - multiples of nineThis challenge was first posted on Slack #regex channel ...

[Live Demo] Watch SOC transformation in action with the reimagined Splunk Enterprise ...

Overwhelmed SOC? Splunk ES Has Your Back Tool sprawl, alert fatigue, and endless context switching are making ...

What’s New & Next in Splunk SOAR

Security teams today are dealing with more alerts, more tools, and more pressure than ever.  Join us on ...