Excel から GridView にデータを取得できます。
以下はコードです:
If Extension = "xls" Then
connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & FileUploadPath & sender.text & ";Extended Properties=""Excel 8.0;HDR=Yes;IMEX=2"""
ElseIf Extension = "xlsx" Then
connString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & FileUploadPath & sender.text & ";Extended Properties=""Excel 12.0;HDR=Yes;IMEX=2"""
End If
Dim query As String = "SELECT * FROM [Sheet1$]"
Dim conn As New OleDbConnection(connString)
If conn.State = ConnectionState.Closed Then
conn.Open()
End If
Dim cmd As New OleDbCommand(query, conn)
Dim da As New OleDbDataAdapter(cmd)
Dim ds As New DataSet
da.Fill(ds)
gvReadFiles.DataSource = ds.Tables(0)
gvReadFiles.DataBind()
da.Dispose()
conn.Close()
conn.Dispose()
ただし、Excel の最初の行のテキストは、GridView のヘッダーのテキストになります。
これも大きな問題ではありませんが、主な問題は、Excel の最初の行でセルが空の場合、GridView で同じヘッダー セルが空にならないことです。その代わりに、F2 のようなテキストが表示されます。
誰かが解決策を知っていますか?