Splunk Search

Spliting single filed into multiple fields based on different delimiters

JP
Explorer

Hi,

I have the following value in a field which needs to be split into multiple fields,

Classname: 

abc.TestAutomation.NNNN.Specs.Prod/NDisableTransactionalAccessUsers.#()::TestAssembly:abc.TestAutomation

Required output:

Productname : abc.TestAutomation.NNNN.Specs.Prod

Feature name : NDisableTransactionalAccessUsers

Project : TestAssembly:abc.TestAutomation

I have been trying to extract the values into my fields using REX command, but I am failing.

source="Reports.csv"  index="prod_reports_data" sourcetype="ReportsData"                                                      |rex "classname(?<Productname>/*)\.(?<Featurename>#*)\.(?<Project>.*)" |table classname Productname Featurename Project

While I execute this command, there are no results.  I am very new to Splunk, can someone guide. 

Thanks.

Labels (2)
0 Karma
1 Solution

bowesmana
SplunkTrust
SplunkTrust

You are getting there, have a look at this query - past the entire query into your search window and you can see how the rex statement works.

| makeresults 
| eval classname="abc.TestAutomation.NNNN.Specs.Prod/NDisableTransactionalAccessUsers.#()::TestAssembly:abc.TestAutomation" 
| rex field=classname "(?<Productname>[^/]*)\/(?<Featurename>[^#]*)#\(\)::(?<Project>.*)" 
| table classname Productname Featurename Project

Note that the regex syntax [^/]* is saying 'find me all characters that are NOT / - different to the way you had written it.

The delimiter #():: is specified as it, but you could do that differently if you expect something different.

I was not sure if classname was a field and whether it was C or c, but hopefully you get the picture.

Hope this helps.

 

View solution in original post

bowesmana
SplunkTrust
SplunkTrust

You are getting there, have a look at this query - past the entire query into your search window and you can see how the rex statement works.

| makeresults 
| eval classname="abc.TestAutomation.NNNN.Specs.Prod/NDisableTransactionalAccessUsers.#()::TestAssembly:abc.TestAutomation" 
| rex field=classname "(?<Productname>[^/]*)\/(?<Featurename>[^#]*)#\(\)::(?<Project>.*)" 
| table classname Productname Featurename Project

Note that the regex syntax [^/]* is saying 'find me all characters that are NOT / - different to the way you had written it.

The delimiter #():: is specified as it, but you could do that differently if you expect something different.

I was not sure if classname was a field and whether it was C or c, but hopefully you get the picture.

Hope this helps.

 

JP
Explorer

Thank you! Works perfect for my requirement.

0 Karma
Get Updates on the Splunk Community!

Application management with Targeted Application Install for Victoria Experience

  Experience a new era of flexibility in managing your Splunk Cloud Platform apps! With Targeted Application ...

Index This | What goes up and never comes down?

January 2026 Edition  Hayyy Splunk Education Enthusiasts and the Eternally Curious!   We’re back with this ...

Splunkers, Pack Your Bags: Why Cisco Live EMEA is Your Next Big Destination

The Power of Two: Splunk &#43; Cisco at "Ludicrous Scale"   You know Splunk. You know Cisco. But have you seen ...