首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >StreamWriter正在将C#中的一些日语字符更改为一些奇怪的字符

StreamWriter正在将C#中的一些日语字符更改为一些奇怪的字符
EN

Stack Overflow用户
提问于 2020-04-26 17:00:34
回答 1查看 35关注 0票数 0

我有一个base64格式的输入字符串displayName,用于比较。

代码语言:javascript
复制
displayName:: Rmlyc3ROYW1lW0FCQ0Q65LqL5qWt5qeL6YCg5pS56Z2p6YOoIOizvOiyt+alreWLmeS8geeUu+OD

geODvOODoF0oRmlyc3ROYW1lKQ==

我们先将base64值转换为byte[],然后使用Encoding.UTF8将其转换为字符串

代码语言:javascript
复制
byte[] newbytes = Convert.FromBase64String(displayname);
string displaynameReadable = Encoding.UTF8.GetString(newbytes);

输出displaynameReadable = FirstName[ABCD:事業構造改革部 購買業務企画チーム](FirstName)

所以在.csv文件中写入值的时候。我正在使用StringWriter。

代码语言:javascript
复制
StringWriter writer;
writer = new StreamWriter(writeFIle);

它必须在csv文件中写入displaynameReadable的值,其中包含日语字符。但是在使用streamWriter之后,它将displaynameReadable的日语字符转换为一些奇怪的字符

流编写器之后的输出:

代码语言:javascript
复制
displayName = FIRSTNAME[ABCD:事業構造改é©éƒ¨ 購買業務ä¼ç”»ãƒãƒ¼ãƒ ](FIRSTNAME)

我猜streamWriter中使用的默认编码是Encoding.UTF8不能在输出文件中获得Japanese字符

EN

回答 1

Stack Overflow用户

发布于 2021-01-05 02:34:57

看起来你已经用Encoding.GetEncoding(1252)写好了输出。参见the result of CyberChef

如果要使.csv文件可用Excel读取,则必须使用Encoding.GetEncoding("utf-8") (带物料清单的UTF8)或Encoding.GetEncoding(932) (MS932)编写.csv

代码语言:javascript
复制
using System;
using System.IO;
using System.Text;

class Program {
    static void Main(string[] args) {
        string displayname = "Rmlyc3ROYW1lW0FCQ0Q65LqL5qWt5qeL6YCg5pS56Z2p6YOoIOizvOiyt+alreWLmeS8geeUu+ODgeODvOODoF0oRmlyc3ROYW1lKQ==";
        byte[] newbytes = Convert.FromBase64String(displayname);
        string displaynameReadable = Encoding.UTF8.GetString(newbytes);
        // Console.WriteLine(displaynameReadable);
        StreamWriter sw = new StreamWriter("/path/to/csv", false, Encoding.GetEncoding("utf-8"));
        sw.WriteLine(displaynameReadable);
        sw.Close();
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61438206

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档