C#保存excel文件时提示文件格式与扩展名不匹配

如果保存生成的excel文件提示如下错误,

可以通过设置保存excel格式来解决。

【例】

public static string xlsFilePath = @"D:\";//excel文件存放路径

 

        /// <summary>

        /// 导出数据到excel文件

        /// </summary>

        /// <param name="dt">要导出的数据集</param>

        /// <returns>生成的文件名</returns>

        static public string ExporeToExcel(DataTable dt)

        {

            MSExcel.Application excelApp = null;

            MSExcel.Workbooks wbks = null;

            MSExcel._Workbook wbk = null;

            try

            {

                string strDir = Directory.GetCurrentDirectory();

                excelApp = new MSExcel.Application();

                excelApp.Visible = false;//是打开不可见

                wbks = excelApp.Workbooks;

                wbk = wbks.Add(true);

 

                String version = excelApp.Version;//获取你使用的excel 的版本号

                int FormatNum;//保存excel文件的格式

                if (Convert.ToDouble(version) < 12)//You use Excel 97-2003

                {

                    FormatNum = -4143;

                }

                else//you use excel 2007 or later

                {

                    FormatNum = 56;

                }

               

                object Nothing = Missing.Value;

                MSExcel._Worksheet whs;

                whs = (MSExcel._Worksheet)wbk.Sheets[1];//获取第一张工作表

                whs.Activate();

 

                //写入标题行

                int rowIndex=1;

                for (int col = 0; col < dt.Columns.Count; col++)

                {

                    whs.Cells[rowIndex, col+1] = dt.Columns[col].Caption.ToString();

                }

                rowIndex++;

                //写入数据内容

                foreach (DataRow row in dt.Rows)

                {

                    for (int colIndex = 0; colIndex < dt.Columns.Count; colIndex++)

                    {

                        whs.Cells[rowIndex, colIndex + 1] = row[colIndex].ToString();

                    }

                    rowIndex++;

                }

 

                excelApp.DisplayAlerts = false;

                //保存excel文件

               

                string newFileName = xlsFilePath + "导出的excel文件" + DateTime.Now.ToString("yyyyMMddhhmmss") + ".xls";

                wbk.SaveAs(newFileName, FormatNum);//保存时候设置保存格式

                //关闭文件

                wbk.Close(false, Nothing, Nothing);

                return newFileName;

              

            }

            catch (Exception e)

            {

                throw e;

            }

            finally

            {

                //wbks.Close();//关闭工作簿

                excelApp.Quit();//关闭excel应用程序

                System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);//释放excel进程

                excelApp = null;

            }

          

        }

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据之道

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值