C#讀Excel小Bug

來源:互聯網
上載者:User

最近用C#讀Excel表中的資料庫

     DataSet ds = new DataSet();
                    txtFile1.Text = openFileDialog1.FileName;
                    OleDbConnection XLSConnection = new OleDbConnection(
                        @"provider=Microsoft.Jet.OLEDB.4.0;data source=" + txtFile1.Text + ";Extended Properties=Excel 8.0;");

                    //Select configuration data from Excel file that make by customer
                    OleDbDataAdapter DA_DB = new OleDbDataAdapter("select * from [DBS$]", XLSConnection);
                    //Fill data into DataSet
                    DA_DB.Fill(ds, "DBS");
                   
                    this.dataGrid1.DataSource = ds;

結果碰到一個奇怪的Bug,有一列的值經常不正確。後來發現如果在開啟Excel表的時候運行程式,讀出的資料就是對的;如果不開啟Excel表,該列讀出的值就是null。

有人指點,建立一個Excel,將各列列名手動輸入,再將資料粘入,讀建立的表剛正常。試了,果然能行,無語。

後來還發現有時候空行過多,也會變成null行。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.