Remove blank rows from CSV file











up vote
1
down vote

favorite












I have a CSV file that contains blank rows like this:



row A

row B
row C


row D


How should I proceed to remove those blank rows to have:



row A
row B
row C
row D


I found many topics on this subject for other languages but none in Ruby.










share|improve this question




















  • 1




    stackoverflow.com/questions/7339292/…
    – Gavriel
    Jan 18 '16 at 11:56















up vote
1
down vote

favorite












I have a CSV file that contains blank rows like this:



row A

row B
row C


row D


How should I proceed to remove those blank rows to have:



row A
row B
row C
row D


I found many topics on this subject for other languages but none in Ruby.










share|improve this question




















  • 1




    stackoverflow.com/questions/7339292/…
    – Gavriel
    Jan 18 '16 at 11:56













up vote
1
down vote

favorite









up vote
1
down vote

favorite











I have a CSV file that contains blank rows like this:



row A

row B
row C


row D


How should I proceed to remove those blank rows to have:



row A
row B
row C
row D


I found many topics on this subject for other languages but none in Ruby.










share|improve this question















I have a CSV file that contains blank rows like this:



row A

row B
row C


row D


How should I proceed to remove those blank rows to have:



row A
row B
row C
row D


I found many topics on this subject for other languages but none in Ruby.







ruby csv






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Jan 18 '16 at 11:59









sawa

128k27193298




128k27193298










asked Jan 18 '16 at 11:50









Graham Slick

2,70132552




2,70132552








  • 1




    stackoverflow.com/questions/7339292/…
    – Gavriel
    Jan 18 '16 at 11:56














  • 1




    stackoverflow.com/questions/7339292/…
    – Gavriel
    Jan 18 '16 at 11:56








1




1




stackoverflow.com/questions/7339292/…
– Gavriel
Jan 18 '16 at 11:56




stackoverflow.com/questions/7339292/…
– Gavriel
Jan 18 '16 at 11:56












2 Answers
2






active

oldest

votes

















up vote
2
down vote



accepted










Three simple steps:



data = File.read('data.csv')                       # Read the file
cleaned = data.gsub(/^$n/, '') # Remove blank lines, from [1]
File.open('out.csv', 'w') { |f| f.write(cleaned) } # Write the cleaned data


[1] Remove empty lines from string






share|improve this answer




























    up vote
    0
    down vote













    You don't have to delete the blank lines, just skip them:



    require "csv" 

    CSV.foreach("path/to/file.csv", skip_blanks: true) do |row|
    # handle row, it won't be blank
    end





    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',
      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%2f34854070%2fremove-blank-rows-from-csv-file%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








      up vote
      2
      down vote



      accepted










      Three simple steps:



      data = File.read('data.csv')                       # Read the file
      cleaned = data.gsub(/^$n/, '') # Remove blank lines, from [1]
      File.open('out.csv', 'w') { |f| f.write(cleaned) } # Write the cleaned data


      [1] Remove empty lines from string






      share|improve this answer

























        up vote
        2
        down vote



        accepted










        Three simple steps:



        data = File.read('data.csv')                       # Read the file
        cleaned = data.gsub(/^$n/, '') # Remove blank lines, from [1]
        File.open('out.csv', 'w') { |f| f.write(cleaned) } # Write the cleaned data


        [1] Remove empty lines from string






        share|improve this answer























          up vote
          2
          down vote



          accepted







          up vote
          2
          down vote



          accepted






          Three simple steps:



          data = File.read('data.csv')                       # Read the file
          cleaned = data.gsub(/^$n/, '') # Remove blank lines, from [1]
          File.open('out.csv', 'w') { |f| f.write(cleaned) } # Write the cleaned data


          [1] Remove empty lines from string






          share|improve this answer












          Three simple steps:



          data = File.read('data.csv')                       # Read the file
          cleaned = data.gsub(/^$n/, '') # Remove blank lines, from [1]
          File.open('out.csv', 'w') { |f| f.write(cleaned) } # Write the cleaned data


          [1] Remove empty lines from string







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Jan 19 '16 at 16:00









          Kristján

          13k42845




          13k42845
























              up vote
              0
              down vote













              You don't have to delete the blank lines, just skip them:



              require "csv" 

              CSV.foreach("path/to/file.csv", skip_blanks: true) do |row|
              # handle row, it won't be blank
              end





              share|improve this answer

























                up vote
                0
                down vote













                You don't have to delete the blank lines, just skip them:



                require "csv" 

                CSV.foreach("path/to/file.csv", skip_blanks: true) do |row|
                # handle row, it won't be blank
                end





                share|improve this answer























                  up vote
                  0
                  down vote










                  up vote
                  0
                  down vote









                  You don't have to delete the blank lines, just skip them:



                  require "csv" 

                  CSV.foreach("path/to/file.csv", skip_blanks: true) do |row|
                  # handle row, it won't be blank
                  end





                  share|improve this answer












                  You don't have to delete the blank lines, just skip them:



                  require "csv" 

                  CSV.foreach("path/to/file.csv", skip_blanks: true) do |row|
                  # handle row, it won't be blank
                  end






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 11 at 1:03









                  steenslag

                  61.1k1199136




                  61.1k1199136






























                      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%2f34854070%2fremove-blank-rows-from-csv-file%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

                      The Sandy Post

                      Danny Elfman

                      Pages that link to "Head v. Amoskeag Manufacturing Co."