Pisanie do doskonałości przy użyciu OleDb

Próbuję wyeksportować wiersze danych z sql do Excela, ale moje polecenie Insert wydaje się nie działać za każdym razem. Spędziłem dużo czasu próbując to stworzyć, ale w końcu podbiegłem do ściany.

Dokument programu Excel to taki, który jest generowany przez IRS i nie jesteśmy w stanie modyfikować niczego powyżej wiersza 16. Wiersz 16 jest wierszem nagłówka, a wszystko, co poniżej musi być danymi z sql. Nazwy nagłówków mają w sobie spacje i wydaje się, że tam, gdzie mam kłopoty.

Począwszy od wiersza 16 nazwy kolumn to: Imię uczestnika, nazwisko uczestnika, uczestnik PTIN, numer programu, godziny CE Przyznany program, data ukończenia

W ten sposób próbuję napisać do programu Excel

private void GenerateReport()
{
    FileInfo xlsFileInfo = new FileInfo(Server.MapPath(CE_REPORTS_PATH + CE_PTIN_TEMPLATE + EXTENSION));

    string connectionString = String.Format(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 8.0;HDR=Yes'", xlsFileInfo.FullName);

    //create connection
    OleDbConnection oleDBConnection = new OleDbConnection(connectionString);
    oleDBConnection.Open();

    //create the adapter with the select to get 
    OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM [Sheet1$A16:F16]", oleDBConnection);

    // Create the dataset and fill it by using the adapter.
    DataTable dataTable = new DataTable();
    adapter.FillSchema(dataTable, SchemaType.Source);
    adapter.Fill(dataTable);

    string[] colNames = new string[dataTable.Columns.Count];
    string[] colParms = new string[dataTable.Columns.Count];

    for (int i = 0; i < dataTable.Columns.Count; i++)
    {
        colNames[i] = String.Format("[{0}]", dataTable.Columns[i].ColumnName);
        colParms[i] = "?";
    }

    // Create Insert Command
    adapter.InsertCommand = new OleDbCommand(String.Format("INSERT INTO [Sheet1$] ({0}) values ({1})", string.Join(",", colNames), string.Join(",", colParms)), oleDBConnection);

    // Create Paramaters
    for (int i = 0; i < dataTable.Columns.Count; i++)
    {
        OleDbParameter param = new OleDbParameter(String.Format("@[{0}]", dataTable.Columns[i].ColumnName), OleDbType.Char, 255, dataTable.Columns[i].ColumnName);
        adapter.InsertCommand.Parameters.Add(param);
    }

    // create a new row
    DataRow newCERecord = dataTable.NewRow();

    // populate row with test data
    for (int i = 0; i < dataTable.Columns.Count; i++)
    {
        newCERecord[i] = "new Data";
    }
    dataTable.Rows.Add(newCERecord);

    // Call update on the adapter to save all the changes to the dataset
    adapter.Update(dataTable);

    oleDBConnection.Close();     
}

Błąd, który pojawia się, gdy wywoływany jest adapter.Update (dataTable), jest następujący

$exception  {"The INSERT INTO statement contains the following unknown field name: 'Attendee First Name'. Make sure you have typed the name correctly, and try the operation again."}   System.Exception {System.Data.OleDb.OleDbException}

Jest to frustrujące, ponieważ pobieram każde pole bezpośrednio z nazwy kolumny, jak otrzymane przez colNames [i] = String.Format ("[{0}]", dataTable.Columns [i] .ColumnName). Odkryłem, że potrzebuję [], aby uwzględnić spacje w nazwach kolumn, ale w tym momencie nie jestem pewien, na czym polega problem. Kiedy patrzę na plik Excela, wszystko wydaje mi się poprawne.

questionAnswers(2)

yourAnswerToTheQuestion