DataTable转成CSV和二进制流,方面导出Excel和转送

该方法将DataTable转换为CSV文件流,同时提供压缩成二进制流的功能,便于Excel导出和数据传输。首先,将中文列头替换为英文,然后将DataTable转化为CSV数据,再通过内存中压缩生成ZIP数据流,最后返回压缩后的二进制数据。

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

/// <summary>
        /// 1 变为CSV文件流
        /// 2 zip压缩
        /// </summary>
        /// <param name="ds"></param>
        /// <returns></returns>
        private byte[] ToCSVFileStream(DataTable ds, Dictionary<string, object> dic)
        {
            //替换中文列头名称
            ds = DataTableColumeName_en2ch(ds, dic);


            //DataTable -> CSV data            
            byte[] data = ExportDataToCSVStream(ds);


            //处理完毕,删除并清理缓存
            ds = null;
            GC.Collect();


            //zip
            byte[] zipData = CSharpZiper.ZipData(data, 6);
            return zipData;
        }

#region DataTalbe -> CSV

        /// <summary>
        /// 导出CSV格式[文件流]
        /// </summary>
        /// <param name="dataTable"></param>
        /// <param name="csvPath"></param>
        private byte[] ExportDataToCSVStream(DataTable dataTable)
        {
            if (dataTable == null || dataTable.Columns.Count == 0 || dataTable.Rows.Count == 0)
            {
                return null;
            }


            StreamEx writer = new StreamEx(true);
            string column = string.Empty;
     
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值