Create and write to a text file inmemory and convert to byte array in one go

HelloWorld picture HelloWorld · Apr 16, 2016 · Viewed 36k times · Source

How can I create a .csv file implicitly/automatically by using the correct method, add text to that file existing in memory and then convert to in memory data to a byte array?

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

With that approach I create a file always (good), write into it (good) then close it (bad) then open the file again from a path and read it from the hard disc (bad)

How can I improve that?

UPDATE

One nearly good approach would be:

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

                using (var memoryStream = new MemoryStream())
                {

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

        }

but I am not able to write text into that filestream... just bytes...

UPDATE 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();
                    }
                }
            }

The string message is not persisted to the test.csv file. Anyone knows why?

Answer

Xilmiki picture Xilmiki · Apr 16, 2016

Write text into Memory Stream.

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);
 }

UPDATE

Use file stream Directly

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