【C#】C#使用OleDb读取Excel出现“外部表不是预期的格式。”

在C#中使用OleDb读取Excel表格数据时,偶现外部表不是预期格式的问题。经多次尝试发现,读取时需打开Excel表格,否则出错。后续查明是公司加密系统所致,解密excel文件即可解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在C#使用OleDb读取Excel表格数据时,出现外部表不是预期的格式,这个问题也是偶现的

这个问题真的很奇怪,一开始也不知为什么,后面问题出现多了,总结出来,是因为在读取表格数据时需要打开Excel表格,试了很多次都是这样,没有打开表格时就出错,打开表格就正常

代码如下:

/// <summary>
/// 读取excel返回DataTable
/// </summary>
/// <param name="fileName"></param>
/// <param name="sheetName"></param>
/// <returns></returns>
private System.Data.DataTable ExcelToDataTable(string fileName, string sheetName)
{
    System.Data.DataTable dt = null;
    try
    {
        string connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileName + ";Extended Properties='Excel 8.0;HDR=No;IMEX=1;'";
        string selectCommandText = "SELECT * FROM [" + sheetName + "$]";

        using (OleDbDataAdapter adapter = new OleDbDataAdapter(selectCommandText, connectionString))
        {
            dt = new System.Data.DataTable();
            adapter.Fill(dt);
            return dt;
        }
    }
    catch(Exception ex)
    {
        MessageBox.Show(ex.ToString());
    }
    return dt;
}

解决方法:打开需要操作的Excel表格再执行读取操作


20200424

后面发现这是由于公司的加密系统导致的,excel文件解密后即可

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

GreAmbWang

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

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

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

打赏作者

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

抵扣说明:

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

余额充值