Solved

View a csv file using a datagridview error

Posted on 2008-10-10
3
242 Views
Last Modified: 2012-05-05
I have this code and every time I run this code I get a error at this line of Code:

Me.DataGridView1.Rows.Add(SplitLine)
 Error: No row can be added to a DataGridView control that does not have columns. Columns must be added first.

I have attached the csv file I'm trying to view in a datagridview

Dim fName As String = ""
 

        OpenFileDialog1.InitialDirectory = "c:\temp\"
 

        OpenFileDialog1.Filter = "CSV files (*.csv)|*.CSV"
 

        OpenFileDialog1.FilterIndex = 2
 

        OpenFileDialog1.RestoreDirectory = True
 

        If (OpenFileDialog1.ShowDialog() = Windows.Forms.DialogResult.OK) Then
 

            fName = OpenFileDialog1.FileName
 

        End If
 
 
 

        Dim TextLine As String = ""
 

        Dim SplitLine() As String
 
 
 

        If System.IO.File.Exists(fName) = True Then
 

            Dim objReader As New System.IO.StreamReader(fName)
 

            Do While objReader.Peek() <> -1
 

                TextLine = objReader.ReadLine()
 

                SplitLine = Split(TextLine, ",")
 

                Me.DataGridView1.Rows.Add(SplitLine)
 

            Loop
 

        Else
 

            MsgBox("File Does Not Exist")
 

        End If

Open in new window

0
Comment
Question by:daruffin
  • 2
3 Comments
 
LVL 11

Accepted Solution

by:
ladarling earned 250 total points
ID: 22687908
The datagridview requires columns, it cant infer generic columns from arrays. Instead of trying to directly add the array to the dgv, add it to a datatable first (which can infer columns). Something like:

Dim dt As New DataTable("myTable") 'declare this in classwide scope

dt.Rows.Add(SplitLine) 'Loop over this

DataGridView1.DataSource = dt.AsDataView 'Finish up with this
0
 

Author Comment

by:daruffin
ID: 22688297
Error Input array is longer than the number of columns in this table

If System.IO.File.Exists(fName) = True Then

            Dim dt As New DataTable("Time")

 

            Dim objReader As New System.IO.StreamReader(fName)

 

            Do While objReader.Peek() <> -1

 

                TextLine = objReader.ReadLine()

 

                SplitLine = Split(TextLine, ",")

                dt.Rows.Add(SplitLine)

                Me.DataGridView1.DataSource = dt.DefaultView

 

            Loop

 

        Else

 

            MsgBox("File Does Not Exist")

 

        End If

0
 

Author Closing Comment

by:daruffin
ID: 31505037
I got it to work and readlly thank you for your help
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

In my previous article (http://www.experts-exchange.com/Programming/Languages/.NET/.NET_Framework_3.x/A_4362-Serialization-in-NET-1.html) we saw the basics of serialization and how types/objects can be serialized to Binary format. In this blog we wi…
In my previous two articles we discussed Binary Serialization (http://www.experts-exchange.com/A_4362.html) and XML Serialization (http://www.experts-exchange.com/A_4425.html). In this article we will try to know more about SOAP (Simple Object Acces…
Internet Business Fax to Email Made Easy - With eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, fr…
Internet Business Fax to Email Made Easy - With  eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, f…

895 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now