Экспорт данных мутилина в одну и ту же ячейку в CSV - PullRequest
0 голосов
/ 10 февраля 2019

Я понимаю, что этот вопрос задавался много раз ( 1 , 2 & 3 ), но я просто не понимаю, как его применять вмое дело.Я пытался играть часами, но я не могу понять это правильно.

У меня есть переменные в виде List<string>, где каждый список содержит данные, у которых есть разрывы строк между ними / многострочные данные.Затем я вызвал событие, которое будет экспортировать эти данные в файл CSV.Ниже мой код.

savestate.cs - класс, в котором я инициализировал переменные

public partial class Savestate
 { 
    public static List<string> rtb1_list = new List<string>();
    public static List<string> rtb2_list = new List<string>();
    public static List<string> rtb3_list = new List<string>();
    public static List<string> rtb4_list = new List<string>();
 }

Form1.cs - Событие

public void Savetocsv()
    {
      Type s = typeof(Savestate);
      FieldInfo[] fields = s.GetFields(BindingFlags.Public | BindingFlags.Static);

      StringBuilder csvdata = new StringBuilder();
      string header = String.Join(",", fields.Select(f => f.Name).ToArray());
      csvdata.AppendLine(header);

      string rtb1 = String.Join(",", Savestate.rtb1_list.ToArray());
      string rtb2 = String.Join(",", Savestate.rtb2_list.ToArray());
      string rtb3 = String.Join(",", Savestate.rtb3_list.ToArray());
      string rtb4 = String.Join(",", Savestate.rtb4_list.ToArray());

      string newlinestring = string.Format("{0}; {1}; {2}; {3}", rtb1, rtb2, rtb3, rtb4);
      csvdata.AppendLine(newlinestring);

      string filepath = @"C:\new.csv";
      File.WriteAllText(filepath, csvdata.ToString());
    }

Однако, когда я открыл файл CSV, слова повсюду.Например, я написал привет , затем новую строку, затем я написал пока .Это фактический вывод , и это мой предполагаемый вывод . Надеюсь, что я могу получить помощь.

Ответы [ 2 ]

0 голосов
/ 10 февраля 2019

Я предлагаю использовать CsvHelper Пакет Nuget при работе с CSV, затем попробуйте сделать следующее, я добавил метод расширения для печати каждого списка rtb одной строкой:

public partial class Savestate
{
    public static List<string> rtb1_list = new List<string>() { "hi", "bye" };
    public static List<string> rtb2_list = new List<string>() { "hi", "bye" };
    public static List<string> rtb3_list = new List<string>() { "hi", "bye" };
    public static List<string> rtb4_list = new List<string>() { "hi", "bye" };
}

public static class SavestateExtensions
{
    public static string GetRtbListAsString(this IEnumerable<string> rtb_list)
    {
        StringBuilder str = new StringBuilder();

        foreach (var value in rtb_list)
        {
            str.AppendLine(value);
        }

        return str.ToString();
    }
}

Затемиспользуйте CsvWriter из CSVHelper:

        using (var writer = new StreamWriter("file.csv"))
        {
            using (var csvWriter = new CsvWriter(writer))
            {
                csvWriter.Configuration.Delimiter = ";";
                csvWriter.Configuration.Encoding = Encoding.UTF8;

                csvWriter.WriteField("rtb1_list ");
                csvWriter.WriteField("rtb2_list ");
                csvWriter.WriteField("rtb3_list ");
                csvWriter.WriteField("rtb4_list ");
                csvWriter.NextRecord();

                csvWriter.WriteField(Savestate.rtb1_list.GetRtbListAsString());
                csvWriter.WriteField(Savestate.rtb2_list.GetRtbListAsString());
                csvWriter.WriteField(Savestate.rtb3_list.GetRtbListAsString());
                csvWriter.WriteField(Savestate.rtb4_list.GetRtbListAsString());
                csvWriter.NextRecord();
            }
        }

Выходные данные должны быть следующими:

enter image description here

0 голосов
/ 10 февраля 2019

Чтобы вставить разрывы строк в файл csv, вам необходимо заключить строку в двойные кавычки, поэтому желаемый вывод генерируется следующим кодом:

public partial class Savestate
{
    public static List<string> rtb1_list = new List<string>() { "hi1", "bye1" };
    public static List<string> rtb2_list = new List<string>() { "hi2", "bye2" };
    public static List<string> rtb3_list = new List<string>() { "hi3", "bye3" };
    public static List<string> rtb4_list = new List<string>() { "hi4", "bye4" };
}
public static void Savetocsv()
{
    Type s = typeof(Savestate);
    FieldInfo[] fields = s.GetFields(BindingFlags.Public | BindingFlags.Static);

    StringBuilder csvdata = new StringBuilder();
    string header = String.Join(",", fields.Select(f => f.Name).ToArray());
    csvdata.AppendLine(header);

    string rtb1 =  String.Join("\n", Savestate.rtb1_list.ToArray());
    string rtb2 =  String.Join("\n", Savestate.rtb2_list.ToArray());
    string rtb3 =  String.Join("\n", Savestate.rtb3_list.ToArray());
    string rtb4 =  String.Join("\n", Savestate.rtb4_list.ToArray());

    string newlinestring = string.Format("\"{0}\",\" {1}\",\" {2}\",\" {3}\"", @rtb1, @rtb2, @rtb3, @rtb4);
    csvdata.AppendLine(newlinestring);

    string filepath = @"new.csv";
    File.WriteAllText(filepath, csvdata.ToString());
}

Выходной файл:

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...