Splunk Search

Extract Fields from JSON

felipesodre
Path Finder

Hi Everyone. Thanks in advance for any help.

I am trying to extract some fields (Status, RecordsPurged)  from a JSON on the following _raw text:

 

 

 

{"": "INFO : 2020-07-09T01:11:08Z : [database@test.com]: {\"Purging_Results_Test\": {\"NewPurging\": 1, \"Status\":\"Successful\", \"VacuumEnabled\": true, \"RecordsPurged\": 6646, \"StartTime\":\"8-Jul-2020 18:03:07\", \"EndTime\":\"8-Jul-2020 18:11:08\", \"Duration(min)\":8.02}}"} 

 

 

 

Any Ideas that might help me out?

 

Thank you so much.

Labels (3)
0 Karma
1 Solution

richgalloway
SplunkTrust
SplunkTrust

You mean like this?

| makeresults 
| eval _raw="{\"\": \"INFO : 2020-07-09T01:11:08Z : [database@test.com]: {\"Purging_Results_Test\": {\"NewPurging\": 1, \"Status\":\"Successful\", \"VacuumEnabled\": true, \"RecordsPurged\": 6646, \"StartTime\":\"8-Jul-2020 18:03:07\", \"EndTime\":\"8-Jul-2020 18:11:08\", \"Duration(min)\":8.02}}\"}"
| rex "Purging_Results_Test\": (?<PurgingResultsTest>.*?})"
| spath input=PurgingResultsTest
---
If this reply helps you, Karma would be appreciated.

View solution in original post

richgalloway
SplunkTrust
SplunkTrust

Normally, one uses spath to parse JSON, but it doesn't like your sample text.  So rex will do, instead.

... | rex "Status\":\"(?<Status>\w+)" | rex "RecordsPurged\": (?<RecordsPurged>\d+)"

 

---
If this reply helps you, Karma would be appreciated.

felipesodre
Path Finder

Hi, sorry for the late reply and thanks for your help.

 

For some reason your code works for some fields and others don't. Please see the image attached.

 

Any ideas that might help?

 

Screen Shot 2020-07-10 at 12.49.06 PM.png

 

Is it possible to get the JSON of Purging_Results: {all content in here} using regex and then navigate to the fields using a spath?

 

Tags (1)
0 Karma

richgalloway
SplunkTrust
SplunkTrust

You mean like this?

| makeresults 
| eval _raw="{\"\": \"INFO : 2020-07-09T01:11:08Z : [database@test.com]: {\"Purging_Results_Test\": {\"NewPurging\": 1, \"Status\":\"Successful\", \"VacuumEnabled\": true, \"RecordsPurged\": 6646, \"StartTime\":\"8-Jul-2020 18:03:07\", \"EndTime\":\"8-Jul-2020 18:11:08\", \"Duration(min)\":8.02}}\"}"
| rex "Purging_Results_Test\": (?<PurgingResultsTest>.*?})"
| spath input=PurgingResultsTest
---
If this reply helps you, Karma would be appreciated.

felipesodre
Path Finder

It just worked perfectly.

Thank you so much, appreciate it!!!!

0 Karma
Get Updates on the Splunk Community!

The OpenTelemetry Certified Associate (OTCA) Exam

What’s this OTCA exam? The Linux Foundation offers the OpenTelemetry Certified Associate (OTCA) credential to ...

From Manual to Agentic: Level Up Your SOC at Cisco Live

Welcome to the Era of the Agentic SOC   Are you tired of being a manual alert responder? The security ...

Splunk Classroom Chronicles: Training Tales and Testimonials (Episode 4)

Welcome back to Splunk Classroom Chronicles, our ongoing series where we shine a light on what really happens ...