jq select or statement












0














I have the the following input json:



{
"TagList": [
{
"Key": "Environment",
"Value": "foo"
},
{
"Key": "ENVIRONMENT",
"Value": "bar"
}
]
}


I want to get the values of tags with the key ENVIRONMENT using jq:



jq -r '.TagList | select(.Key=="ENVIRONMENT") | .Value' input.json


But as it turned out, the key could be also Environment. I try get both using this command:



jq -r '.TagList | select((.Key=="ENVIRONMENT") | .Value' or .Key=="Environment" | .Value)


but get the following error:



jq: error: syntax error, unexpected $end, expecting ';' or ')' (Unix shell quoting issues?) at <top-level>, line 1:
.TagList | select((.Key=="ENVIRONMENT") | .Value
jq: 1 compile error


How to get both of those tags?










share|improve this question
























  • @eekfonky Please update your question with the output sample JSON.
    – Mohit Kumar
    Nov 23 '18 at 15:03






  • 1




    learn how to create an mcve. I prepared that for you this time in order to show what it means. All the aws stuff was totally unnecessary on the one hand, and on the other hand was missing every useful information to reproduce the problem for others. Please review this again and post the actual command that failed. The one you posted doesn't make sense at all (because of the broken quoting)
    – hek2mgl
    Nov 23 '18 at 15:21


















0














I have the the following input json:



{
"TagList": [
{
"Key": "Environment",
"Value": "foo"
},
{
"Key": "ENVIRONMENT",
"Value": "bar"
}
]
}


I want to get the values of tags with the key ENVIRONMENT using jq:



jq -r '.TagList | select(.Key=="ENVIRONMENT") | .Value' input.json


But as it turned out, the key could be also Environment. I try get both using this command:



jq -r '.TagList | select((.Key=="ENVIRONMENT") | .Value' or .Key=="Environment" | .Value)


but get the following error:



jq: error: syntax error, unexpected $end, expecting ';' or ')' (Unix shell quoting issues?) at <top-level>, line 1:
.TagList | select((.Key=="ENVIRONMENT") | .Value
jq: 1 compile error


How to get both of those tags?










share|improve this question
























  • @eekfonky Please update your question with the output sample JSON.
    – Mohit Kumar
    Nov 23 '18 at 15:03






  • 1




    learn how to create an mcve. I prepared that for you this time in order to show what it means. All the aws stuff was totally unnecessary on the one hand, and on the other hand was missing every useful information to reproduce the problem for others. Please review this again and post the actual command that failed. The one you posted doesn't make sense at all (because of the broken quoting)
    – hek2mgl
    Nov 23 '18 at 15:21
















0












0








0







I have the the following input json:



{
"TagList": [
{
"Key": "Environment",
"Value": "foo"
},
{
"Key": "ENVIRONMENT",
"Value": "bar"
}
]
}


I want to get the values of tags with the key ENVIRONMENT using jq:



jq -r '.TagList | select(.Key=="ENVIRONMENT") | .Value' input.json


But as it turned out, the key could be also Environment. I try get both using this command:



jq -r '.TagList | select((.Key=="ENVIRONMENT") | .Value' or .Key=="Environment" | .Value)


but get the following error:



jq: error: syntax error, unexpected $end, expecting ';' or ')' (Unix shell quoting issues?) at <top-level>, line 1:
.TagList | select((.Key=="ENVIRONMENT") | .Value
jq: 1 compile error


How to get both of those tags?










share|improve this question















I have the the following input json:



{
"TagList": [
{
"Key": "Environment",
"Value": "foo"
},
{
"Key": "ENVIRONMENT",
"Value": "bar"
}
]
}


I want to get the values of tags with the key ENVIRONMENT using jq:



jq -r '.TagList | select(.Key=="ENVIRONMENT") | .Value' input.json


But as it turned out, the key could be also Environment. I try get both using this command:



jq -r '.TagList | select((.Key=="ENVIRONMENT") | .Value' or .Key=="Environment" | .Value)


but get the following error:



jq: error: syntax error, unexpected $end, expecting ';' or ')' (Unix shell quoting issues?) at <top-level>, line 1:
.TagList | select((.Key=="ENVIRONMENT") | .Value
jq: 1 compile error


How to get both of those tags?







jq






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 23 '18 at 15:12









hek2mgl

106k13142164




106k13142164










asked Nov 23 '18 at 14:52









eekfonky

1891314




1891314












  • @eekfonky Please update your question with the output sample JSON.
    – Mohit Kumar
    Nov 23 '18 at 15:03






  • 1




    learn how to create an mcve. I prepared that for you this time in order to show what it means. All the aws stuff was totally unnecessary on the one hand, and on the other hand was missing every useful information to reproduce the problem for others. Please review this again and post the actual command that failed. The one you posted doesn't make sense at all (because of the broken quoting)
    – hek2mgl
    Nov 23 '18 at 15:21




















  • @eekfonky Please update your question with the output sample JSON.
    – Mohit Kumar
    Nov 23 '18 at 15:03






  • 1




    learn how to create an mcve. I prepared that for you this time in order to show what it means. All the aws stuff was totally unnecessary on the one hand, and on the other hand was missing every useful information to reproduce the problem for others. Please review this again and post the actual command that failed. The one you posted doesn't make sense at all (because of the broken quoting)
    – hek2mgl
    Nov 23 '18 at 15:21


















@eekfonky Please update your question with the output sample JSON.
– Mohit Kumar
Nov 23 '18 at 15:03




@eekfonky Please update your question with the output sample JSON.
– Mohit Kumar
Nov 23 '18 at 15:03




1




1




learn how to create an mcve. I prepared that for you this time in order to show what it means. All the aws stuff was totally unnecessary on the one hand, and on the other hand was missing every useful information to reproduce the problem for others. Please review this again and post the actual command that failed. The one you posted doesn't make sense at all (because of the broken quoting)
– hek2mgl
Nov 23 '18 at 15:21






learn how to create an mcve. I prepared that for you this time in order to show what it means. All the aws stuff was totally unnecessary on the one hand, and on the other hand was missing every useful information to reproduce the problem for others. Please review this again and post the actual command that failed. The one you posted doesn't make sense at all (because of the broken quoting)
– hek2mgl
Nov 23 '18 at 15:21














2 Answers
2






active

oldest

votes


















2














You can use the following command:



jq '.TagList|select(.Key=="Environment" or .Key=="ENVIRONMENT").Value'





share|improve this answer





























    1














    Generalizing a bit:



    .TagList
    | select(.Key | ascii_upcase == "ENVIRONMENT").Value





    share|improve this answer





















      Your Answer






      StackExchange.ifUsing("editor", function () {
      StackExchange.using("externalEditor", function () {
      StackExchange.using("snippets", function () {
      StackExchange.snippets.init();
      });
      });
      }, "code-snippets");

      StackExchange.ready(function() {
      var channelOptions = {
      tags: "".split(" "),
      id: "1"
      };
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function() {
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled) {
      StackExchange.using("snippets", function() {
      createEditor();
      });
      }
      else {
      createEditor();
      }
      });

      function createEditor() {
      StackExchange.prepareEditor({
      heartbeatType: 'answer',
      autoActivateHeartbeat: false,
      convertImagesToLinks: true,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: 10,
      bindNavPrevention: true,
      postfix: "",
      imageUploader: {
      brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
      contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
      allowUrls: true
      },
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      });


      }
      });














      draft saved

      draft discarded


















      StackExchange.ready(
      function () {
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53448845%2fjq-select-or-statement%23new-answer', 'question_page');
      }
      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      2














      You can use the following command:



      jq '.TagList|select(.Key=="Environment" or .Key=="ENVIRONMENT").Value'





      share|improve this answer


























        2














        You can use the following command:



        jq '.TagList|select(.Key=="Environment" or .Key=="ENVIRONMENT").Value'





        share|improve this answer
























          2












          2








          2






          You can use the following command:



          jq '.TagList|select(.Key=="Environment" or .Key=="ENVIRONMENT").Value'





          share|improve this answer












          You can use the following command:



          jq '.TagList|select(.Key=="Environment" or .Key=="ENVIRONMENT").Value'






          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 23 '18 at 15:14









          hek2mgl

          106k13142164




          106k13142164

























              1














              Generalizing a bit:



              .TagList
              | select(.Key | ascii_upcase == "ENVIRONMENT").Value





              share|improve this answer


























                1














                Generalizing a bit:



                .TagList
                | select(.Key | ascii_upcase == "ENVIRONMENT").Value





                share|improve this answer
























                  1












                  1








                  1






                  Generalizing a bit:



                  .TagList
                  | select(.Key | ascii_upcase == "ENVIRONMENT").Value





                  share|improve this answer












                  Generalizing a bit:



                  .TagList
                  | select(.Key | ascii_upcase == "ENVIRONMENT").Value






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 23 '18 at 18:20









                  peak

                  30.4k83956




                  30.4k83956






























                      draft saved

                      draft discarded




















































                      Thanks for contributing an answer to Stack Overflow!


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid



                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.


                      To learn more, see our tips on writing great answers.





                      Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                      Please pay close attention to the following guidance:


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid



                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.


                      To learn more, see our tips on writing great answers.




                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function () {
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53448845%2fjq-select-or-statement%23new-answer', 'question_page');
                      }
                      );

                      Post as a guest















                      Required, but never shown





















































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown

































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown







                      Popular posts from this blog

                      A CLEAN and SIMPLE way to add appendices to Table of Contents and bookmarks

                      Calculate evaluation metrics using cross_val_predict sklearn

                      Insert data from modal to MySQL (multiple modal on website)