.Net 下使用ODBC连接xls文件写入大文本的解决办法

在.NET环境下使用ODBC连接Excel文件时遇到大文本被截断为256个字符的问题。经研究,由于数据引擎通过扫描前八行确定单元格类型。解决方案是在首行相应列输入超长文本,确保Excel不再自动截断。通过此方法,可以成功写入大文本数据。

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

问题:

      在.net 下通过ODBC写入大文本,发现xls单元格自动把文本截断为256个字符,同样的代码写入SQL Server 的text字段没有问题。

     研究发现,主要是没法告诉xls文件单元格的格式(在excel里面设置为文本也不起做用),查询google后发现(http://support.microsoft.com/kb/257819)数据引擎是通过扫描xls文件前八行来确定类型的,于是手工在第一行对应列(单元内容)输入超过256个字符,再用程序插入数据的时候,excel就没有再截断了。

    代码如下:



    

        public bool WriteToXls(DataTable dt,string asheetname)
        {
            if (dt != null && dt.Rows.Count > 0)
            {
                bool result = false;
                using( OdbcConnection con = new OdbcConnection())
                {
                    string sheetname = "[" + asheetname +
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值