LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Reading a CSV file ... extra rows ??

Solved!
Go to solution

 I am trying to read a CSV file created with Excel 2010 on a WIN10 laptop. 

I am getting the rows always wrong... the CSV file was originally having 17 rows and now has data only in 10 rows. I want to be able to read and report only 10 rows. If you the code display  mode of the read CSV data, you will see spaces appearing in the empty file. How to over come this ? I tried deleting the contents of the empty rows in Excel but nothing helps. Any idea how to handle such a situation [or] how to REALLY empty the rows without data in Excel ??

 

CSV_Read.pngCSV DataRead.PNG

Raghunathan
LabVIEW to Automate Hydraulic Test rigs.
0 Kudos
Message 1 of 15
(10,100 Views)

Edit the file in a text editor such as Notepad.  Excel can never seem to get a CSV right for me either.



There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
Message 2 of 15
(10,094 Views)

What happens if you delete the rows and not just clear the cell contents?  It looks like you may have some type of formatting rule that is creating the extra spaces.  Clearing cell contents doesn't remove formatting rules. 

aputman
0 Kudos
Message 3 of 15
(10,076 Views)

As an experiment, you can:

  • create a blank workbook
  • highlight the first 5 rows and columns
  • right click and format
  • change the number format to something other than General (I think anything other than General will work.  I didn't try them all.)
  • export to a CSV file

When you open the CSV file with a text editor, you'll get 5 rows that each contain 5 commas, even though no data is written in the cells.

aputman
Message 4 of 15
(10,070 Views)

Hi Raghunathan,

 

Try to copy the 10 rows and paste it in the new excel file.

Delete the old file and rename the new file by the name of the old file.

 

Regards,

Fred.

 

Kudos are welcome!Smiley Wink

 

0 Kudos
Message 5 of 15
(10,065 Views)

Those extra rows have spaces in them.  You say you are deleting the data, but are you sure?

 

Just delete the actual rows.

0 Kudos
Message 6 of 15
(10,062 Views)
Solution
Accepted by crossrulz

There are several different flavors of CSV files in Excel.  Which one did you use to save it with?

 

To t-shoot this issue, I'd open up the original file in something like notepad++ (or even just plain ol' notepad) so you can see exactly what you have in that file.  Odds are there's something wrong with the file.

Bill
CLD
(Mid-Level minion.)
My support system ensures that I don't look totally incompetent.
Proud to say that I've progressed beyond knowing just enough to be dangerous. I now know enough to know that I have no clue about anything at all.
Humble author of the CLAD Nugget.
Message 7 of 15
(10,058 Views)

@MogaRaghu wrote:

 I am trying to read a CSV file created with Excel 2010 on a WIN10 laptop. 

I am getting the rows always wrong... the CSV file was originally having 17 rows and now has data only in 10 rows. I want to be able to read and report only 10 rows. If you the code display  mode of the read CSV data, you will see spaces appearing in the empty file. How to over come this ? I tried deleting the contents of the empty rows in Excel but nothing helps. Any idea how to handle such a situation [or] how to REALLY empty the rows without data in Excel ??

 

 


This won't fix what is wrong with your file but of you only need the first 10 rows why don't you:

  1. Only read the first 10 rows instead of the entire file
  2. Or split the array at row 10 and forget about the rest?
========================
=== Engineer Ambiguously ===
========================
0 Kudos
Message 8 of 15
(10,043 Views)

@RTSLVU wrote:

This won't fix what is wrong with your file but of you only need the first 10 rows why don't you:

  1. Only read the first 10 rows instead of the entire file
  2. Or split the array at row 10 and forget about the rest?

Another option:

1. Read the entire file as a string (Read From Text File).

2. Use Trim Whitespace.  This will clear out all of the spaces, tabs, end of lines, etc at each end of the file.

3. Use Spreadsheet String To Array to convert to a 2D array.



There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
Message 9 of 15
(10,022 Views)

@crossrulz wrote:

@RTSLVU wrote:

This won't fix what is wrong with your file but of you only need the first 10 rows why don't you:

  1. Only read the first 10 rows instead of the entire file
  2. Or split the array at row 10 and forget about the rest?

Another option:

1. Read the entire file as a string (Read From Text File).

2. Use Trim Whitespace.  This will clear out all of the spaces, tabs, end of lines, etc at each end of the file.

3. Use Spreadsheet String To Array to convert to a 2D array.


Exactly!

 

I think what has been missed here is the csv file in question is NOT the problem, well it is but... Your program should be robust enough to deal with a few extra blank lines and/or display an error message that the incoming file is invalid.

 

I rwrote a program that end users create "test scripts" using Excel. But I also provide a detailed Excel template (.xltx) that tells then exactly how to enter their parameters and exactly what format to save the file in.

 

Upon loading the test scrip (a .csv file) first all of the "extra stuff" from the template (directions, notes, etc) are removed, then it is checked for basic errors (formatting, columns all filled in, etc), and finally all of the entered parameters are checked against a config file to ensure test parameters are within the range of the equipment and instruments.

 

If any of this fails I popup an error dialog telling the user that the test script has errors.

========================
=== Engineer Ambiguously ===
========================
Message 10 of 15
(10,017 Views)