How can I parse through a log file, extract certain values and construct a tab or comma delimited text file?












0















I am trying to convert a pre-formatted section within a log file into a comma or tab delimited tabular view.



Here's a sample section contained in the log file:



Appliance-01> home
Appliance-01> show debug lldp
logout

LLDP information:

IfIdx 16 ("1/1/1") Information:
Chassis ID: XYZ0-ABCD-EFGH0(SWITCH01)
System name: XYZ0-ABCD-EFGH0(SWITCH01)
System description: SOME-SWITCH
Software version: Cisco OS
Platform:
Port ID: Ethernet1/40
Port description: Ethernet1/40
Management address: 10.20.30.41
Time to live: 180s (170s remaining)

IfIdx 17 ("1/1/2") Information:
Chassis ID: XYZ0-ABCD-EFGH0(SWITCH02)
System name: XYZ0-ABCD-EFGH0(SWITCH02)
System description: SOME-SWITCH
Software version: Cisco OS
Platform:
Port ID: Ethernet1/40
Port description: Ethernet1/40
Management address: 10.20.30.42
Time to live: 180s (170s remaining)


I would like this to look like this:



Appliance Name, Interface, Chassis ID, System name, Port ID, Port Desc, Mgmt addr
Appliance-01, IfIdx 16 ("1/1/1"), XYZ0-ABCD-EFGH0(SWITCH01), XYZ0-ABCD-EFGH0(SWITCH01), Ethernet1/40, Ethernet1/40, 10.20.30.41
Appliance-01, IfIdx 17 ("1/1/2"), XYZ0-ABCD-EFGH0(SWITCH02), XYZ0-ABCD-EFGH0(SWITCH02), Ethernet1/40, Ethernet1/40, 10.20.30.42


And then eventually utilize the same script to parse through a large number of log files and produce a much larger output.










share|improve this question





























    0















    I am trying to convert a pre-formatted section within a log file into a comma or tab delimited tabular view.



    Here's a sample section contained in the log file:



    Appliance-01> home
    Appliance-01> show debug lldp
    logout

    LLDP information:

    IfIdx 16 ("1/1/1") Information:
    Chassis ID: XYZ0-ABCD-EFGH0(SWITCH01)
    System name: XYZ0-ABCD-EFGH0(SWITCH01)
    System description: SOME-SWITCH
    Software version: Cisco OS
    Platform:
    Port ID: Ethernet1/40
    Port description: Ethernet1/40
    Management address: 10.20.30.41
    Time to live: 180s (170s remaining)

    IfIdx 17 ("1/1/2") Information:
    Chassis ID: XYZ0-ABCD-EFGH0(SWITCH02)
    System name: XYZ0-ABCD-EFGH0(SWITCH02)
    System description: SOME-SWITCH
    Software version: Cisco OS
    Platform:
    Port ID: Ethernet1/40
    Port description: Ethernet1/40
    Management address: 10.20.30.42
    Time to live: 180s (170s remaining)


    I would like this to look like this:



    Appliance Name, Interface, Chassis ID, System name, Port ID, Port Desc, Mgmt addr
    Appliance-01, IfIdx 16 ("1/1/1"), XYZ0-ABCD-EFGH0(SWITCH01), XYZ0-ABCD-EFGH0(SWITCH01), Ethernet1/40, Ethernet1/40, 10.20.30.41
    Appliance-01, IfIdx 17 ("1/1/2"), XYZ0-ABCD-EFGH0(SWITCH02), XYZ0-ABCD-EFGH0(SWITCH02), Ethernet1/40, Ethernet1/40, 10.20.30.42


    And then eventually utilize the same script to parse through a large number of log files and produce a much larger output.










    share|improve this question



























      0












      0








      0








      I am trying to convert a pre-formatted section within a log file into a comma or tab delimited tabular view.



      Here's a sample section contained in the log file:



      Appliance-01> home
      Appliance-01> show debug lldp
      logout

      LLDP information:

      IfIdx 16 ("1/1/1") Information:
      Chassis ID: XYZ0-ABCD-EFGH0(SWITCH01)
      System name: XYZ0-ABCD-EFGH0(SWITCH01)
      System description: SOME-SWITCH
      Software version: Cisco OS
      Platform:
      Port ID: Ethernet1/40
      Port description: Ethernet1/40
      Management address: 10.20.30.41
      Time to live: 180s (170s remaining)

      IfIdx 17 ("1/1/2") Information:
      Chassis ID: XYZ0-ABCD-EFGH0(SWITCH02)
      System name: XYZ0-ABCD-EFGH0(SWITCH02)
      System description: SOME-SWITCH
      Software version: Cisco OS
      Platform:
      Port ID: Ethernet1/40
      Port description: Ethernet1/40
      Management address: 10.20.30.42
      Time to live: 180s (170s remaining)


      I would like this to look like this:



      Appliance Name, Interface, Chassis ID, System name, Port ID, Port Desc, Mgmt addr
      Appliance-01, IfIdx 16 ("1/1/1"), XYZ0-ABCD-EFGH0(SWITCH01), XYZ0-ABCD-EFGH0(SWITCH01), Ethernet1/40, Ethernet1/40, 10.20.30.41
      Appliance-01, IfIdx 17 ("1/1/2"), XYZ0-ABCD-EFGH0(SWITCH02), XYZ0-ABCD-EFGH0(SWITCH02), Ethernet1/40, Ethernet1/40, 10.20.30.42


      And then eventually utilize the same script to parse through a large number of log files and produce a much larger output.










      share|improve this question
















      I am trying to convert a pre-formatted section within a log file into a comma or tab delimited tabular view.



      Here's a sample section contained in the log file:



      Appliance-01> home
      Appliance-01> show debug lldp
      logout

      LLDP information:

      IfIdx 16 ("1/1/1") Information:
      Chassis ID: XYZ0-ABCD-EFGH0(SWITCH01)
      System name: XYZ0-ABCD-EFGH0(SWITCH01)
      System description: SOME-SWITCH
      Software version: Cisco OS
      Platform:
      Port ID: Ethernet1/40
      Port description: Ethernet1/40
      Management address: 10.20.30.41
      Time to live: 180s (170s remaining)

      IfIdx 17 ("1/1/2") Information:
      Chassis ID: XYZ0-ABCD-EFGH0(SWITCH02)
      System name: XYZ0-ABCD-EFGH0(SWITCH02)
      System description: SOME-SWITCH
      Software version: Cisco OS
      Platform:
      Port ID: Ethernet1/40
      Port description: Ethernet1/40
      Management address: 10.20.30.42
      Time to live: 180s (170s remaining)


      I would like this to look like this:



      Appliance Name, Interface, Chassis ID, System name, Port ID, Port Desc, Mgmt addr
      Appliance-01, IfIdx 16 ("1/1/1"), XYZ0-ABCD-EFGH0(SWITCH01), XYZ0-ABCD-EFGH0(SWITCH01), Ethernet1/40, Ethernet1/40, 10.20.30.41
      Appliance-01, IfIdx 17 ("1/1/2"), XYZ0-ABCD-EFGH0(SWITCH02), XYZ0-ABCD-EFGH0(SWITCH02), Ethernet1/40, Ethernet1/40, 10.20.30.42


      And then eventually utilize the same script to parse through a large number of log files and produce a much larger output.







      awk sed grep scripting csv






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Feb 9 at 6:44









      Rui F Ribeiro

      40.4k1479137




      40.4k1479137










      asked Feb 8 at 22:05









      hopeless_scriptorhopeless_scriptor

      11




      11






















          0






          active

          oldest

          votes











          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "106"
          };
          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: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          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%2funix.stackexchange.com%2fquestions%2f499569%2fhow-can-i-parse-through-a-log-file-extract-certain-values-and-construct-a-tab-o%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes
















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • 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%2funix.stackexchange.com%2fquestions%2f499569%2fhow-can-i-parse-through-a-log-file-extract-certain-values-and-construct-a-tab-o%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

          How to make a Squid Proxy server?

          第一次世界大戦

          Touch on Surface Book