Конвертировать XML-ответ в файл .CSV - PullRequest
1 голос
/ 25 января 2011

У меня есть следующий код,

Я отправляю массив данных в веб-службу, ответ от веб-службы отображается в настоящее время в веб-форме, как показано ниже.

private void Form1_Load(object sender, EventArgs e)
    {
        int ASent;
        int CSent;
        webservice.Results returned = convert();
        txtResult.Text = System.Convert.ToString(returned.status);
        txtMoreRes1.Text = returned.errorDetails[0].errorDetails;
        txtMoreRes2.Text = returned.errorDetails[1].errorDetails;
        txtMoreRes3.Text = returned.errorDetails[2].errorDetails;
        txtMoreRes4.Text = returned.errorDetails[3].errorDetails;
        date.Text = System.Convert.ToString(DateTime.Today);
        time.Text = System.Convert.ToString(DateTime.Now.TimeOfDay);
                }

Теперь мне нужно, чтобы возвращаемые результаты были преобразованы из ответа xml в файл .csv.Затем попросите код сохранить этот .csv в папку на диске C.Как я могу изменить свой код, чтобы сделать это?

Спасибо за ваше время!

Ответы [ 3 ]

0 голосов
/ 25 января 2011

Вы также можете использовать FileHelpers , чтобы сделать это.Вы должны создать класс с именем MyClass с атрибутами, которые соответствуют вашему формату .csv (каждый столбец = один атрибут), создать список объектов такого класса и преобразовать в csv таким образом, используя FileHelper:

FileHelperEngine engine = new FileHelperEngine(typeof(MyClass));

MyClass[] res = null; //Fill your array here from your code.

// To Write Use:
engine.WriteFile("FileOut.txt", res);
0 голосов
/ 25 января 2011

Вы также можете сделать это с помощью XML-преобразования .

0 голосов
/ 25 января 2011
 StringBuilder SbCSV = new StringBuilder();
            int ActualSent;
            int CommitmentSent;
            webservice.summaryResults returned = convert(out ActualSent, out CommitmentSent);
            //txtResult.Text = System.Convert.ToString(returned.status);
            SbCSV.Append(System.Convert.ToString(returned.status));
            //txtMoreRes1.Text = returned.errorDetails[0].errorDetails;
            SbCSV.Append("," + returned.errorDetails[0].errorDetails);
            //txtMoreRes2.Text = returned.errorDetails[1].errorDetails;
            SbCSV.Append("," + returned.errorDetails[1].errorDetails);
            // Similary ...
            txtMoreRes3.Text = returned.errorDetails[2].errorDetails;
            txtMoreRes4.Text = returned.errorDetails[3].errorDetails;
            actualSum.Text = System.Convert.ToString(returned.actualSum);
            commitmentSum.Text = System.Convert.ToString(returned.commitmentSum);
            date.Text = System.Convert.ToString(DateTime.Today);
            time.Text = System.Convert.ToString(DateTime.Now.TimeOfDay);
            actualsumsent.Text = ActualSent.ToString();
            commitmentsumsent.Text = CommitmentSent.ToString();
            errorposition1.Text = System.Convert.ToString(returned.errorDetails[0].errorPosition);
            errorposition2.Text = System.Convert.ToString(returned.errorDetails[1].errorPosition);
            errorposition3.Text = System.Convert.ToString(returned.errorDetails[2].errorPosition);
            errorposition4.Text = System.Convert.ToString(returned.errorDetails[3].errorPosition);

            TextWriter Tw = new StreamWriter("Your_FilePath_Name.csv");
            Tw.Write(SbCSV.ToString());
            Tw.Close();
            Tw.Dispose();
...