Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/259.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 将现有CSV文件保存为Excel中的CSV文件会更改编码_C#_.net_Excel_Csv_Encoding - Fatal编程技术网

C# 将现有CSV文件保存为Excel中的CSV文件会更改编码

C# 将现有CSV文件保存为Excel中的CSV文件会更改编码,c#,.net,excel,csv,encoding,C#,.net,Excel,Csv,Encoding,我有一个CSV文件,其中包含'á'字符。当我在.NET中使用StreamReader导入此文件时,它会正确显示。但是,当我从Excel保存对话框中保存与CSV相同的文件副本,然后使用流阅读器在.NET中导入新文件时,“á”字符显示为�'. 仅当从流编码中选中时,这两个文件的编码才为UTF-8。请提出这个问题的解决方案 我没有streamreader,但如果我将包含“á”的句子粘贴到Excel中,然后将其保存为CSV或CSV-UTF8,然后在记事本++中打开它,“á”将保留在文件中。因此,Exce

我有一个CSV文件,其中包含'á'字符。当我在.NET中使用StreamReader导入此文件时,它会正确显示。但是,当我从Excel保存对话框中保存与CSV相同的文件副本,然后使用流阅读器在.NET中导入新文件时,“á”字符显示为�'.


仅当从流编码中选中时,这两个文件的编码才为UTF-8。请提出这个问题的解决方案

我没有
streamreader
,但如果我将包含“á”的句子粘贴到Excel中,然后将其保存为CSV或CSV-UTF8,然后在记事本++中打开它,“á”将保留在文件中。因此,Excel似乎并不是在消除“A”。保存文件时,您可能正在执行一些不同的操作?如果我将文件保存为CSV(MSDOS)或CSV(Macintosh),则不会保留“á”。什么版本的Excel?@RonRosenfeld Excel O365。在excel之类的应用程序中,我还可以看到字符被保留。问题是,当我在C#Net中使用StreamReader读取新文件时,它会在该字符的位置显示问号。当我将文件另存为CSV Unicode时,这很好。但当我在常规CSV中保存时,这个问题仍然存在。我希望你明白我的意思。再说一遍,我不熟悉
StreamReader
。但我看到,当Excel编写一个
UTF-8 CSV
时,它在文件的开头包含可选的
BOM
EF BB BF
)。
StreamReader
(或者您是如何使用它的)是否对此有问题?@RonRosenfeld当我将其保存为CSV(UTF-8)时,它工作正常。问题是当我从菜单中将其保存为CSV时。如果不指定
UTF-8
,Excel似乎不会将BOM表放在文件的开头。但是,如果Excel打开包含BOM表的CSV,则除非指定非UTF8格式,否则它似乎会在保存时保留该BOM表。在你的过程中还发生了其他事情。