BS系统导出csv文件用excel打开的乱码问题

本文探讨了从ASP.NET应用程序导出CSV文件时遇到的Excel兼容性问题。具体表现为直接输出内存中CSV内容到浏览器时,Excel打开会出现中文乱码。通过对比分析发现原因在于文件的BOM签名差异。

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

很早前做过一个ASP.NET的多语言版本的小系统,其中一个功能是将报表导出为csv文件。以前的实现方式是先在服务器创建一个UTF-8的临时文件,然后将文件流输出至浏览器。一直这样来用,没有什么问题。

最近想修改一下,因为觉得每次都要创建文件有些不爽。于是直接将内存中csv的内容输出至浏览器(Response的Encoding也是utf-8)。在client端下载文件后,使用记事本、editplus、ultra-edit等工具打开均可以正常显示,但是用excel打开时,所有的中文均变成乱码。

于是将前一种方式下载的文件命名为A.CSV,后一种方式的命名为B.CSV。仔细比较过两种方式生成文件内容,一模一样,在editplus下查看encoding,均为utf-8编码。

在MSDN上确认了EXCEL不支持UTF-8格式。之后在网上看了下unicode的BOM介绍,自己动手用ultra-edit以二进制方式打开两个文件,原来是A的方式生成有unicode的BOM签名,而B的没有,所以导致了A可以正常被显示,而B显示为乱码。

 

没办法,只好采用前一种方式了...

 

 

 

转载于:https://www.cnblogs.com/foreverbeta/archive/2009/07/03/1516537.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值