關於Excel 不同版本在C#導入時的應用

 前段時間,在進行Excel導入程序編寫時,就使用網上一些人寫的方法,直接進行導入. 代碼如下:

 

        public KPISExcel(string fileName)
        {
            try {
                //Start Excel and get Application object.
                oXL = new Excel.Application();//Microsoft.Office.Interop.Excel.Application();
                oXL.Visible = false;
               
                //Get a new workbook.
                //Open a excel file ,which contain bom data, and do not update links ,and readonly.
                oWB = oXL.Workbooks.Open(fileName, 0, true,
                    Type.Missing, Type.Missing, Type.Missing,
                    Type.Missing, Type.Missing, Type.Missing,
                    Type.Missing, Type.Missing, Type.Missing,
                    Type.Missing, Type.Missing, Type.Missing);

                oSheet = (_Worksheet)oWB.Sheets[1];
            } catch (Exception e) {
                throw e;
            }
        }

 

本來以為,基本沒有沒有任何問題. 程序正式通過測試,並且上線. 後來,一些業務人員不斷的反映它的Excel無法導入,都是使用Excel 97-2003的版本的. 想了半天,無法比較出到底有什麼差別. 後來,仔細比較後,發現文件大小不相同. 同樣的數據的Excel,得到的大小確是不相同,真是讓我鬱悶死了.  後來,使用UltraEdit進行比較,的確是有些不相同.

 

後來,在網上查詢資料時發現,Excel 2000與Excel 2003存儲的資料大小不相同,而且使用導入時,使用的Excel 2003時,調用的Open的參數是15位. 而使用Excel 2000時,使用的是13位. 因此,出現這樣的狀況.

 

程序更改如下:

 

      public KPISExcel(string fileName)
        {
            try {
                //Start Excel and get Application object.
                oXL = new Excel.Application();//Microsoft.Office.Interop.Excel.Application();
                oXL.Visible = false;
               
                //Get a new workbook.
                //Open a excel file ,which contain bom data, and do not update links ,and readonly.
                //oWB = oXL.Workbooks.Open(fileName, 0, true,
                //    Type.Missing, Type.Missing, Type.Missing,
                //    Type.Missing, Type.Missing, Type.Missing,
                //    Type.Missing, Type.Missing, Type.Missing,
                //    Type.Missing, Type.Missing, Type.Missing);

                //上面的方法只支持Excel2003
                //下面的方法可以支持Excel2000與Excel2003
                oWB = oXL.Workbooks._Open(fileName, 0, true,
                    Type.Missing, Type.Missing, Type.Missing,
                    Type.Missing, Type.Missing, Type.Missing,
                    Type.Missing, Type.Missing, Type.Missing,
                    Type.Missing);

                oSheet = (_Worksheet)oWB.Sheets[1];
            } catch (Exception e) {
                close();
                throw e;
            }
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值