Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6726523
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 26, 20262026-05-26T09:56:15+00:00 2026-05-26T09:56:15+00:00

How can I use OLEDB to parse and import a CSV file that each

  • 0

How can I use OLEDB to parse and import a CSV file that each cell is encased in double quotes because some rows contain commas in them?? I am unable to change the format as it is coming from a vendor.

I am trying the following and it is failing with an IO error:

public DataTable ConvertToDataTable(string fileToImport, string fileDestination)
{
    string fullImportPath = fileDestination + @"\" + fileToImport;
    OleDbDataAdapter dAdapter = null;
    DataTable dTable = null;

    try
    {
        if (!File.Exists(fullImportPath))
            return null;

        string full = Path.GetFullPath(fullImportPath);
        string file = Path.GetFileName(full);
        string dir = Path.GetDirectoryName(full);


        //create the "database" connection string
        string connString = "Provider=Microsoft.Jet.OLEDB.4.0;"
          + "Data Source=\"" + dir + "\\\";"
          + "Extended Properties=\"text;HDR=No;FMT=Delimited\"";

        //create the database query
        string query = "SELECT * FROM " + file;

        //create a DataTable to hold the query results
        dTable = new DataTable();

        //create an OleDbDataAdapter to execute the query
        dAdapter = new OleDbDataAdapter(query, connString);


        //fill the DataTable
        dAdapter.Fill(dTable);
    }
    catch (Exception ex)
    {
        throw new Exception(CLASS_NAME + ".ConvertToDataTable: Caught Exception: " + ex);
    }
    finally
    {
        if (dAdapter != null)
            dAdapter.Dispose();
    }

    return dTable;
}

When I use a normal CSV it works fine. Do I need to change something in the connString??

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-26T09:56:15+00:00Added an answer on May 26, 2026 at 9:56 am

    Just incase anyone has a similar issue, i wanted to post the code i used. i did end up using Textparser to get the file and parse ot the columns, but i am using recrusion to get the rest done and substrings.

     /// <summary>
            /// Parses each string passed as a "row".
            /// This routine accounts for both double quotes
            /// as well as commas currently, but can be added to
            /// </summary>
            /// <param name="row"> string or row to be parsed</param>
            /// <returns></returns>
            private List<String> ParseRowToList(String row)
            {
                List<String> returnValue = new List<String>();
    
                if (row[0] == '\"')
                {// Quoted String
                    if (row.IndexOf("\",") > -1)
                    {// There are more columns
                        returnValue = ParseRowToList(row.Substring(row.IndexOf("\",") + 2));
                        returnValue.Insert(0, row.Substring(1, row.IndexOf("\",") - 1));
                    }
                    else
                    {// This is the last column
                        returnValue.Add(row.Substring(1, row.Length - 2));
                    }
                }
                else
                {// Unquoted String
                    if (row.IndexOf(",") > -1)
                    {// There are more columns
                        returnValue = ParseRowToList(row.Substring(row.IndexOf(",") + 1));
                        returnValue.Insert(0, row.Substring(0, row.IndexOf(",")));
                    }
                    else
                    {// This is the last column
                        returnValue.Add(row.Substring(0, row.Length));
                    }
                }
    
                return returnValue;
    
            }
    

    Then the code for Textparser is:

     // string pathFile = @"C:\TestFTP\TestCatalog.txt";
                string pathFile = @"C:\TestFTP\SomeFile.csv";
    
                List<String> stringList = new List<String>();
                TextFieldParser fieldParser = null;
                DataTable dtable = new DataTable();
    
                /* Set up TextFieldParser
                    *  use the correct delimiter provided
                    *  and path */
                fieldParser = new TextFieldParser(pathFile);
                /* Set that there are quotes in the file for fields and or column names */
                fieldParser.HasFieldsEnclosedInQuotes = true;
    
                /* delimiter by default to be used first */
                fieldParser.SetDelimiters(new string[] { "," });
    
                // Build Full table to be imported
                dtable = BuildDataTable(fieldParser, dtable);
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

In a 32-bit .NET app, I can use this OLEDB connection string to connect
I can use VS08's MFC/ActiveX template to create a C++ ActiveX object that I
Can I use PHP with Oledb connection? As far as I know database connection
How can I make sure that a certain OLEDB driver is installed when I
You can use more than one css class in an HTML tag in current
You can use a standard dot notation or a method call in Objective-C to
I can use properties of an Excel Worksheet to tell if the worksheet is
You can use ftplib for full FTP support in Python. However the preferred way
You can use SelectFolder() to get a folder or GetOpenFolderitem(filter as string) to get
You can use App.config; but it only supports key/value pairs. You can use .Net

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.