Подтвердить что ты не робот

Создавайте и записывайте в текстовый файл inmemory и конвертируйте в массив байтов за один раз

Как я могу создать файл .csv неявно/автоматически, используя правильный метод, добавить текст в этот файл, существующий в памяти, а затем преобразовать в данные памяти в массив байтов?

string path = @"C:\test.txt";
File.WriteAllLines(path, GetLines());
byte[] bytes = System.IO.File.ReadAllBytes(path);

С таким подходом я создаю файл всегда (хорошо), записываю в него (хорошо), затем закрываю его (плохо), затем снова открываю файл из пути и читаю его с жесткого диска (плохо)

Как я могу улучшить это?

ОБНОВЛЕНИЕ

Один очень хороший подход:

  using (var fs = new FileStream(@"C:\test.csv", FileMode.Create, FileAccess.ReadWrite))
            {

                using (var memoryStream = new MemoryStream())
                {

                    fs.CopyTo(memoryStream );
                    return memoryStream .ToArray();
                }

        }

но я не могу написать текст в этот файл... просто байты...

ОБНОВЛЕНИЕ 2

 using (var fs = File.Create(@"C:\temp\test.csv"))
            {
                using (var sw = new StreamWriter(fs, Encoding.Default))
                {
                    using (var ms = new MemoryStream())
                    {
                        String message = "Message is the correct ääüö Pi(\u03a0), and Sigma (\u03a3).";
                        sw.Write(message);
                        sw.Flush();
                        fs.CopyTo(ms);
                        return ms.ToArray();
                    }
                }
            }

Строковое сообщение не сохраняется в файле test.csv. Кто-нибудь знает почему?

4b9b3361

Ответ 1

Введите текст в поток памяти.

byte[] bytes = null;
 using (var ms = new MemoryStream())
 {
     TextWriter tw = new StreamWriter(ms);
     tw.Write("blabla");
     tw.Flush();
     ms.Position = 0;
     bytes = ms.ToArray();
     //or save to disk using FileStream (fs)
     ms.WriteTo(fs);
 }

ОБНОВЛЕНИЕ

Использовать поток файлов Непосредственно

 using (var fs = new FileStream(@"C:\sh\test.csv", FileMode.Create, FileAccess.ReadWrite))
 {
     TextWriter tw = new StreamWriter(fs);
     tw.Write("blabla");
     tw.Flush();
 }

Ответ 2

Вы можете получить байтовый массив из строки, используя кодировку:

Encoding.ASCII.GetBytes(aString);

Или же

Encoding.UTF8.GetBytes(aString);

Но я не знаю, почему вы хотели бы CSV в качестве байтов. Вы можете загрузить весь файл в строку, добавить к нему, а затем сохранить его:

string content;

using (var reader = new StreamReader(filename))
{
    content = reader.ReadToEnd();
}

content += "x,y,z";

using (var writer = new StreamWriter(filename))
{
    writer.Write(content);
}

Обновление: создайте CSV в памяти и передайте обратно как байты:

var stringBuilder = new StringBuilder();
foreach(var line in GetLines())
{
    stringBuilder.AppendLine(log);
}
return Encoding.ASCII.GetBytes(stringBuilder.ToString());