<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Programmatically parse random key name in json for subfield in Splunk Search</title>
    <link>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494685#M137885</link>
    <description>&lt;P&gt;Why I don't want to use rex...&lt;/P&gt;

&lt;P&gt;I have some events that have more than one foo above and I need to basically grab foo.&lt;EM&gt;.fqdn sometimes, and later grab otherfoo.&lt;/EM&gt;.fqdn, knowing which one I am grabbing.&lt;/P&gt;</description>
    <pubDate>Wed, 11 Mar 2020 20:06:29 GMT</pubDate>
    <dc:creator>mmccul_fe</dc:creator>
    <dc:date>2020-03-11T20:06:29Z</dc:date>
    <item>
      <title>Programmatically parse random key name in json for subfield</title>
      <link>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494684#M137884</link>
      <description>&lt;P&gt;Data resembles this pattern.  &lt;/P&gt;

&lt;PRE&gt;&lt;CODE&gt;| makeresults 
| eval _raw="{\"foo\": [{\"randstring1\": {\"fqdn\" : \"ibar.example.com\"}}, {\"randstring2\": {\"fqdn\" : \"jbar.example.com\"} }]}"
&lt;/CODE&gt;&lt;/PRE&gt;

&lt;P&gt;I am trying to extract the two FQDNs when the containing field name foo{}.* is a random string.  Any hints on how to get this data?&lt;/P&gt;

&lt;P&gt;I've tried a few different options with spath and can't seem to get it to work.  I &lt;EM&gt;could&lt;/EM&gt; try a rex, but I was really hoping to avoid that.&lt;/P&gt;

&lt;P&gt;Basically, what I want at the end is a field (multivalue in this case) that has as value &lt;STRONG&gt;ibar.example.com&lt;/STRONG&gt; and &lt;STRONG&gt;jbar.example.com&lt;/STRONG&gt;.&lt;/P&gt;</description>
      <pubDate>Wed, 11 Mar 2020 18:14:27 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494684#M137884</guid>
      <dc:creator>mmccul_fe</dc:creator>
      <dc:date>2020-03-11T18:14:27Z</dc:date>
    </item>
    <item>
      <title>Re: Programmatically parse random key name in json for subfield</title>
      <link>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494685#M137885</link>
      <description>&lt;P&gt;Why I don't want to use rex...&lt;/P&gt;

&lt;P&gt;I have some events that have more than one foo above and I need to basically grab foo.&lt;EM&gt;.fqdn sometimes, and later grab otherfoo.&lt;/EM&gt;.fqdn, knowing which one I am grabbing.&lt;/P&gt;</description>
      <pubDate>Wed, 11 Mar 2020 20:06:29 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494685#M137885</guid>
      <dc:creator>mmccul_fe</dc:creator>
      <dc:date>2020-03-11T20:06:29Z</dc:date>
    </item>
    <item>
      <title>Re: Programmatically parse random key name in json for subfield</title>
      <link>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494686#M137886</link>
      <description>&lt;P&gt;@mmccul_fe like this?&lt;/P&gt;

&lt;PRE&gt;&lt;CODE&gt;| makeresults 
| eval _raw="{\"foo\": [{\"randstring1\": {\"fqdn\" : \"ibar.example.com\"}}, {\"randstring2\": {\"fqdn\" : \"jbar.example.com\"} }]}" 
| spath 
| rename foo{}.* as * randstring*.fqdn as randstring*
| eval fqdn = ""
| foreach randstring* [eval fqdn = fqdn + " " + '&amp;lt;&amp;lt;FIELD&amp;gt;&amp;gt;']
&lt;/CODE&gt;&lt;/PRE&gt;

&lt;P&gt;Note: the screenshot is an older image, i've renamed column3 "randstring" to fqdn in my answer&lt;/P&gt;

&lt;P&gt;Results:&lt;BR /&gt;
&lt;span class="lia-inline-image-display-wrapper" image-alt="alt text"&gt;&lt;img src="https://community.splunk.com/t5/image/serverpage/image-id/8543i39C3DA329A1CD82D/image-size/large?v=v2&amp;amp;px=999" role="button" title="alt text" alt="alt text" /&gt;&lt;/span&gt;&lt;/P&gt;</description>
      <pubDate>Thu, 12 Mar 2020 05:38:35 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494686#M137886</guid>
      <dc:creator>anmolpatel</dc:creator>
      <dc:date>2020-03-12T05:38:35Z</dc:date>
    </item>
    <item>
      <title>Re: Programmatically parse random key name in json for subfield</title>
      <link>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494687#M137887</link>
      <description>&lt;PRE&gt;&lt;CODE&gt;....
|rex max_match=0 "\"fqdn\" : \"(?&amp;lt;fqdn&amp;gt;.*?)\""
&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Thu, 12 Mar 2020 08:30:23 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494687#M137887</guid>
      <dc:creator>to4kawa</dc:creator>
      <dc:date>2020-03-12T08:30:23Z</dc:date>
    </item>
    <item>
      <title>Re: Programmatically parse random key name in json for subfield</title>
      <link>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494688#M137888</link>
      <description>&lt;P&gt;such a neat solution &lt;span class="lia-unicode-emoji" title=":slightly_smiling_face:"&gt;🙂&lt;/span&gt; &lt;/P&gt;</description>
      <pubDate>Fri, 13 Mar 2020 01:16:38 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494688#M137888</guid>
      <dc:creator>anmolpatel</dc:creator>
      <dc:date>2020-03-13T01:16:38Z</dc:date>
    </item>
    <item>
      <title>Re: Programmatically parse random key name in json for subfield</title>
      <link>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494689#M137889</link>
      <description>&lt;P&gt;Like this:&lt;/P&gt;

&lt;PRE&gt;&lt;CODE&gt;| makeresults 
| eval _raw="{\"foo\": [{\"randstring1\": {\"fqdn\" : \"ibar.example.com\"}}, {\"randstring2\": {\"fqdn\" : \"jbar.example.com\"} }]}"
| kv
| foreach *fqdn [ eval mvfield=mvappend(mvfield, '&amp;lt;&amp;lt;FIELD&amp;gt;&amp;gt;') ]
&lt;/CODE&gt;&lt;/PRE&gt;

&lt;P&gt;This way, as long as the fields end in &lt;CODE&gt;fqdn&lt;/CODE&gt;, you get them merged into a field called &lt;CODE&gt;mvfield&lt;/CODE&gt;.&lt;/P&gt;</description>
      <pubDate>Sat, 14 Mar 2020 21:37:30 GMT</pubDate>
      <guid>https://community.splunk.com/t5/Splunk-Search/Programmatically-parse-random-key-name-in-json-for-subfield/m-p/494689#M137889</guid>
      <dc:creator>woodcock</dc:creator>
      <dc:date>2020-03-14T21:37:30Z</dc:date>
    </item>
  </channel>
</rss>

