Создайте текстовый файл без BOM

Я попробовал этот подход без любого успеха

код я использую:

// File name
String filename = String.Format("{0:ddMMyyHHmm}", dtFileCreated);
String filePath = Path.Combine(Server.MapPath("App_Data"), filename + ".txt");

// Process       
myObject pbs = new myObject();         
pbs.GenerateFile();

// pbs.GeneratedFile is a StringBuilder object

// Save file
Encoding utf8WithoutBom = new UTF8Encoding(true);
TextWriter tw = new StreamWriter(filePath, false, utf8WithoutBom);
foreach (string s in pbs.GeneratedFile.ToArray()) 
    tw.WriteLine(s);
tw.Close();

// Push Generated File into Client
Response.Clear();
Response.ContentType = "application/vnd.text";
Response.AppendHeader("Content-Disposition", "attachment; filename=" + filename + ".txt");
Response.TransmitFile(filePath);
Response.End();

результат:

enter image description here

Это пишет BOM независимо от того, что, и специальные символы (как Æ Ø Å) не корректно :-/

Я застреваю!

Моя цель, создают файл с помощью UTF-8 в качестве Кодирования и 8859-1 как CharSet

Это настолько трудно выполнить, или я просто получаю плохой день?

Вся справка значительно ценится, спасибо!

51
задан Community 23 May 2017 в 00:31
поделиться

1 ответ

Ну, он пишет спецификацию, потому что вы указываете это в строке

Encoding utf8WithoutBom = new UTF8Encoding(true);

true ] означает, что спецификация должна быть выпущена, при использовании

Encoding utf8WithoutBom = new UTF8Encoding(false);

спецификация не записывается.

Моя цель - создать файл, используя UTF-8 в качестве кодировки и 8859-1 в качестве CharSet

К сожалению, это невозможно, независимо от того, пишете вы UTF-8 или нет. Т.е. пока символы, которые вы пишете, присутствуют в ISO Latin-1, он будет выглядеть как файл ISO 8859-1, однако, как только вы выведете символ, не охватываемый ISO 8859-1 (например, ä, ö, ü ) эти символы будут записаны как многобайтовые символы.

Чтобы написать истинный ISO-8859-1, используйте:

Encoding isoLatin1Encoding = Encoding.GetEncoding("ISO-8859-1");

Изменить: После комментария Балександра

я использовал следующий код для тестирования ...

var filePath = @"c:\temp\test.txt";
var sb = new StringBuilder();
sb.Append("dsfaskd jlsadfj laskjdflasjdf asdkfjalksjdf lkjdsfljas dddd jflasjdflkjasdlfkjasldfl asääääjdflkaslj d f");

Encoding isoLatin1Encoding = Encoding.GetEncoding("ISO-8859-1");

TextWriter tw = new StreamWriter(filePath, false, isoLatin1Encoding);
tw.WriteLine(sb.ToString());
tw.Close();

И файл выглядит отлично. Очевидно, вы должны использовать ту же кодировку при чтении файла .

124
ответ дан 7 November 2019 в 09:56
поделиться
Другие вопросы по тегам:

Похожие вопросы: