C# 中文数据导出CSV出现乱码

最近遇到一个问题,就是输出到csv文件时,含有中文字符会乱码的现象。
1、问题分析
首先,c#一般的文件写入是采用utf8的编码,无独有偶,excel正好不兼容这种格式的编码,因此excel会用ansi的编码进行解析你的文档,出现乱码。

2、解决方式
因此,采用系统默认的编码方式ansi就能和excel达成一致,顺利解决乱码情况

在后面添加上Encoding就可以啦

using( StreamWriter fs=new StreamWriter(f.FullName,true,Encoding.Default))
{
      fs.write("字符串");
}
  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你可以尝试使用以下代码来读取包含中文CSV文件,并解决乱码问题: ```csharp using System; using System.Collections.Generic; using System.IO; using System.Text; public class CsvReader { private string filePath; private string delimiter; public CsvReader(string filePath, string delimiter = ",") { this.filePath = filePath; this.delimiter = delimiter; } public List<List<string>> ReadCsvFile() { List<List<string>> csvData = new List<List<string>>(); using (var reader = new StreamReader(filePath, Encoding.Default)) { while (!reader.EndOfStream) { var line = reader.ReadLine(); var values = line.Split(delimiter); List<string> row = new List<string>(); foreach (var value in values) { row.Add(value); } csvData.Add(row); } } return csvData; } } public class Program { public static void Main(string[] args) { string filePath = "your_file_path.csv"; CsvReader csvReader = new CsvReader(filePath); List<List<string>> csvData = csvReader.ReadCsvFile(); // 打印CSV文件内容 foreach (var row in csvData) { foreach (var value in row) { Console.Write(value + "\t"); } Console.WriteLine(); } } } ``` 在上述代码中,我们使用了 `StreamReader` 类来读取CSV文件,并使用 `Encoding.Default` 来指定默认的编码。如果你的CSV文件采用其他编码方式,你可以根据实际情况进行调整。 请将 `your_file_path.csv` 替换为你的CSV文件的实际路径。此代码将CSV文件的内容打印到控制台,你可以根据需要进行后续处理。 希望这可以帮助到你!如果你有任何其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值