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!

Enterprise Security Content Update (ESCU) | New Releases

In December, the Splunk Threat Research Team had 1 release of new security content via the Enterprise Security ...

Why am I not seeing the finding in Splunk Enterprise Security Analyst Queue?

(This is the first of a series of 2 blogs). Splunk Enterprise Security is a fantastic tool that offers robust ...

Index This | What are the 12 Days of Splunk-mas?

December 2024 Edition Hayyy Splunk Education Enthusiasts and the Eternally Curious!  We’re back with another ...