1. 程式人生 > >C#讀EXCEL 檔案,資料型別問題

C#讀EXCEL 檔案,資料型別問題

在使用 ADO.NET 匯出 Excel 檔案時,設定 IMEX=1 仍不能匯出所有資料的解決辦法作者:孟憲會 發表於:2010-11-17 15:32:39 今天遇到一個問題,在使用 ADO.NET 匯出 Excel 檔案時,連線字串裡面已經設定了 IMEX=1,仍有部分資料不能匯出,經過研究,需要在登錄檔中進行設定 TypeGuessRows 的配置,預設情況下,驅動程式會掃描前 8 行資料,來對資料型別進行取樣。設定為 0 ,將對列的所有行進行掃描,如果前八行取樣資料都是數值型別的話,設定 IMEX = 1 也不會將剩下的行的預設資料型別轉換為文字,它將保留數值型別,也就是把整個列當成數字型別對待。 因此,要想得到完整的資料,需要修改登錄檔的設定 TypeGuessRows 為 0。TypeGuessRows 在登錄檔的位置: [HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Jet/4.0/Engines/Excel] Windows 7等 64 系統: [HKEY_LOCAL_MACHINE/SOFTWARE/Wow6432Node/Microsoft/Jet/4.0/Engines/Excel] IMEX 的可能設定是: 0 Export 模式 1 Import 模式 2 Linked 模式(full update capabilities) 設定 TypeGuessRows 為 0 將會導致效能的下降。IMEX=1 資料內容也能出現不正常的現象,比如長數字可能會出現科學計數法的格式顯示。比較好的做法是匯出前,對所有單元格進行處理,在單元格內容前面加 '。