如何在C#中将字符串转换为UTF-8?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在C#中将字符串转换为UTF-8?相关的知识,希望对你有一定的参考价值。
我有一个字符串,我从第三方应用程序收到,我想在我的Windows Surface上使用C#以任何语言正确显示它。
由于编码不正确,我的字符串在西班牙语中看起来像这样:
行动组织
而它应该是这样的:
行动
根据这个问题的答案:How to know string encoding in C#,我收到的编码应该是UTF-8,但它是在Encoding.Default(可能是ANSI?)上读取的。
我试图将这个字符串转换为真正的UTF-8,但其中一个问题是我只能看到Encoding类的一个子集(仅限UTF8和Unicode属性),可能是因为我只限于windows表面API。
我已经尝试了一些我在互联网上找到的片段,但到目前为止,东部语言(即韩语)都没有证明它们是成功的。一个例子如下:
var utf8 = Encoding.UTF8;
byte[] utfBytes = utf8.GetBytes(myString);
myString= utf8.GetString(utfBytes, 0, utfBytes.Length);
我也尝试将字符串解压缩为字节数组,然后使用UTF8.GetString:
byte[] myByteArray = new byte[myString.Length];
for (int ix = 0; ix < myString.Length; ++ix)
{
char ch = myString[ix];
myByteArray[ix] = (byte) ch;
}
myString = Encoding.UTF8.GetString(myByteArray, 0, myString.Length);
你们有其他想法我可以试试吗?
如你所知,字符串以Encoding.Default
形式出现,你可以简单地使用:
byte[] bytes = Encoding.Default.GetBytes(myString);
myString = Encoding.UTF8.GetString(bytes);
您可能需要记住的另一件事:如果您使用Console.WriteLine输出一些字符串,那么您还应该编写Console.OutputEncoding = System.Text.Encoding.UTF8;
!或者所有utf8字符串都将作为gbk输出...
string utf8String = "Acción";
string propEncodeString = string.Empty;
byte[] utf8_Bytes = new byte[utf8String.Length];
for (int i = 0; i < utf8String.Length; ++i)
{
utf8_Bytes[i] = (byte)utf8String[i];
}
propEncodeString = Encoding.UTF8.GetString(utf8_Bytes, 0, utf8_Bytes.Length);
输出应该是这样的
行动
那天是显示日
调用DecodeFromUtf8();
private static void DecodeFromUtf8()
{
string utf8_String = "day’s";
byte[] bytes = Encoding.Default.GetBytes(utf8_String);
utf8_String = Encoding.UTF8.GetString(bytes);
}
您的代码正在读取一系列UTF8编码的字节,并使用8位编码对其进行解码。
您需要修复该代码以将字节解码为UTF8。
或者(不理想),您可以将坏字符串转换回原始字节数组 - 通过使用不正确的编码对其进行编码 - 然后将字节重新解码为UTF8。
如果要将任何字符串保存到mysql数据库,请执行以下操作: - >
您的数据库字段结构我phpmyadmin [或任何其他控制面板]应设置为utf8-gerneral-ci
2)你应该改变你的字符串[例如textbox1.text]到字节,因此
2-1)定义byte [] st2;
2-2)将你的字符串[textbox1.text]转换为unicode [mmultibyte string]:
byte[] st2 = System.Text.Encoding.UTF8.GetBytes(textBox1.Text);
3)在任何查询之前执行此sql命令:
string mysql_query2 = "SET NAMES 'utf8'";
cmd.CommandText = mysql_query2;
cmd.ExecuteNonQuery();
3-2)现在您应该将此值插入到例如名称字段中:
cmd.CommandText = "INSERT INTO customer (`name`) values (@name)";
4)许多解决方案没有注意的主要工作是以下行:你应该使用addwithvalue而不是添加命令参数如下:
cmd.Parameters.AddWithValue("@name",ut);
++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Encoding.Convert(Encoding.Default, Encoding.UTF8, Encoding.Default.GetBytes(mystring));
使用以下代码段从csv文件中获取字节
protected byte[] GetCSVFileContent(string fileName)
{
StringBuilder sb = new StringBuilder();
using (StreamReader sr = new StreamReader(fileName, Encoding.Default, true))
{
String line;
// Read and display lines from the file until the end of
// the file is reached.
while ((line = sr.ReadLine()) != null)
{
sb.AppendLine(line);
}
}
string allines = sb.ToString();
UTF8Encoding utf8 = new UTF8Encoding();
var preamble = utf8.GetPreamble();
var data = utf8.GetBytes(allines);
return data;
}
请拨打以下电话并将其另存为附件
Encoding csvEncoding = Encoding.UTF8;
//byte[] csvFile = GetCSVFileContent(FileUpload1.PostedFile.FileName);
byte[] csvFile = GetCSVFileContent("Your_CSV_File_NAme");
string attachment = String.Format("attachment; filename={0}.csv", "uomEncoded");
Response.Clear();
Response.ClearHeaders();
Response.ClearContent();
Response.ContentType = "text/csv";
Response.ContentEncoding = csvEncoding;
Response.AppendHeader("Content-Disposition", attachment);
//Response.BinaryWrite(csvEncoding.GetPreamble());
Response.BinaryWrite(csvFile);
Response.Flush();
Response.End();
以上是关于如何在C#中将字符串转换为UTF-8?的主要内容,如果未能解决你的问题,请参考以下文章