Arquivo Excel com linha de cabeçalho (para versões 97 - 2003) usando .NET xlReader for Microsoft Excel

Exemplo de string de conexão com Excel usando .NET xlReader for Microsoft Excel

Exemplo de string de conexão

Essa é uma string de conexão .NET xlReader for Microsoft Excel para se conectar com Excel 2003, Excel 2002, Excel 2000 ou Excel 97.

Arquivo Excel com linha de cabeçalho (para versões 97 - 2003)

Data Source =C:\Diretorio\Arquivo.xls;HDR=yes;Format=xls;

Conexão através de diferentes linguagens

C#

Exemplo de código em C# de conexão com Excel usando .NET xlReader for Microsoft Excel:

using System;
using VM.xPort.ExcelClient;

class DatabaseConnection {
    static void Main() {
        // Define a string de conexão Excel usando .NET xlReader for Microsoft Excel
        string connectionString = "Data Source =C:\\Diretorio\\Arquivo.xls;HDR=yes;Format=xls;";

        using (ExcelConnection connection = new ExcelConnection(connectionString)) {
            try {
                // Abre a conexão
                connection.Open();

                Console.WriteLine("Conexão aberta com sucesso!");

                //
                // INSIRA SEU CÓDIGO AQUI
                //
            }
            catch (ExcelException ex) {
                // Erros específicos do ExcelException
                Console.WriteLine("Erro: " + ex.Message);
            }
            catch (Exception ex) {
                // Outros erros
                Console.WriteLine("Erro: " + ex.Message);            
            }
            finally {
                // Fecha a conexão
                if (connection != null) {
                    connection.Close();
                    Console.WriteLine("Conexão fechada.");
                }
            }
        }
    }
}

Alternativamente, você pode usar o código abaixo, que usa a classe DbProviderFactory:

using System;
using System.Data.Common;

class DatabaseConnection {
    static void Main() {
        /// Define a string de conexão Excel usando .NET xlReader for Microsoft Excel
        string connectionString = "Data Source =C:\\Diretorio\\Arquivo.xls;HDR=yes;Format=xls;";

        // Cria o objeto factory usando o namespace VM.xPort.ExcelClient
        DbProviderFactory factory = DbProviderFactories.GetFactory("VM.xPort.ExcelClient");

        using (DbConnection connection = factory.CreateConnection()) {
            if (connection == null) {
                Console.WriteLine("Não foi possível criar a conexão.");
                return;
            }

            connection.ConnectionString = connectionString;

            try {
                // Abre a conexão
                connection.Open();
                Console.WriteLine("Conexão aberta com sucesso!");

                //
                // INSIRA SEU CÓDIGO AQUI
                //
            }
            catch (DbException ex) {
                // Erros específicos do DbException
                Console.WriteLine("Erro: " + ex.Message);
            }
            catch (Exception ex) {
                // Outros erros
                Console.WriteLine("Erro: " + ex.Message);
            }
            finally {
                // Fecha a conexão
                if (connection != null) {
                    connection.Close();
                    Console.WriteLine("Conexão fechada.");
                }
            }
        }
    }
}

VB.NET

Exemplo de código em VB.NET de conexão com Excel usando .NET xlReader for Microsoft Excel:

Imports System
Imports VM.xPort.ExcelClient

Public Class DatabaseConnection
    Public Shared Sub Main()
        ' Define a string de conexão Excel usando .NET xlReader for Microsoft Excel
        Dim connectionString As String = "Data Source =C:\Diretorio\Arquivo.xls;HDR=yes;Format=xls;"

        Using connection As New ExcelConnection(connectionString)
            Try
                ' Abre a conexão
                connection.Open()

                Console.WriteLine("Conexão aberta com sucesso!")

                '
                ' INSIRA SEU CÓDIGO AQUI
                '

            Catch ex As ExcelException
                ' Erros específicos do ExcelException
                Console.WriteLine("Erro: " & ex.Message)
            Catch ex As Exception
                ' Outros erros
                Console.WriteLine("Erro: " & ex.Message)
            Finally
                ' Fecha a conexão
                If connection IsNot Nothing Then
                    connection.Close()
                    Console.WriteLine("Conexão fechada.")
                End If
            End Try
        End Using
    End Sub
End Class

Alternativamente, você pode usar o código abaixo, que usa a classe DbProviderFactory:

Imports System
Imports System.Data.Common

Public Class DatabaseConnection
    Public Shared Sub Main()
        ' Define a string de conexão Excel usando .NET xlReader for Microsoft Excel
        Dim connectionString As String = "Data Source =C:\Diretorio\Arquivo.xls;HDR=yes;Format=xls;"

        ' Cria o objeto factory usando o namespace VM.xPort.ExcelClient
        Dim factory As DbProviderFactory = DbProviderFactories.GetFactory("VM.xPort.ExcelClient")

        Using connection As DbConnection = factory.CreateConnection()
            If connection Is Nothing Then
                Console.WriteLine("Não foi possível criar a conexão.")
                Return
            End If

            connection.ConnectionString = connectionString

            Try
                ' Abre a conexão
                connection.Open()
                Console.WriteLine("Conexão aberta com sucesso!")

                '
                ' INSIRA SEU CÓDIGO AQUI
                '

            Catch ex As DbException
                ' Erros específicos do DbException
                Console.WriteLine("Erro: " & ex.Message)
            Catch ex As Exception
                ' Outros erros
                Console.WriteLine("Erro: " & ex.Message)
            Finally
                ' Fecha a conexão
                If connection IsNot Nothing Then
                    connection.Close()
                    Console.WriteLine("Conexão fechada.")
                End If
            End Try
        End Using
    End Sub
End Class