xmlserialize классы - PullRequest
       30

xmlserialize классы

0 голосов
/ 17 июня 2020

мой код ниже. Я застрял на этом последние несколько дней. Изначально мне дали схему. Я преобразовал этот xsd в .cs. Затем я создал несколько классов из схемы, потому что мне легче читать и меньше кода. В любом случае, мне удалось преобразовать файл Excel, содержащий около 20+ заголовков и 200 строк, в набор данных, который отображается в сетке данных. Моя цель - показать таблицу в datagrid2, преобразовать информацию в сериализованную xml do c для сохранения в заданную папку c, а также отобразить данные xml в datagridview3 рядом с окном datagrid2.

Но я не смог пройти стадию преобразования в Excel. Код работает до этой строки: MessageBox.Show (ex.ToString ()) ;. Я попытался сопоставить набор данных с таблицей. Я пробовал xmlreader, xmlwriter, create и xmlserialize. Но всегда что-то происходит не так. Самое большее, что я получил с файлом, - это документ xml, который создается без ничего. Я включил 2 класса. Спасибо за вашу помощь. Я очень ценю это. Я обновил код и все еще работаю над ним. Буду очень признателен за помощь. Спасибо.

      using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml.Serialization;
using Excel = Microsoft.Office.Interop.Excel;

namespace exceltoxmlnew2
  {
  public partial class Form1 : Form
  {
    public Form1()
    {
        InitializeComponent();
    }

    private void Form1_Load(object sender, EventArgs e)
    {

    }
    private void button2_Click(object sender, EventArgs e)
    {
        //DataTable dt;
        //public System.Data.Common.DataTableMappingCollection 
     TableMappings { get; }
        try
            {
           // public System.Data.Common.DataTableMappingCollection 
TableMappings { get; }
                System.Data.OleDb.OleDbConnection MyConnection;
                System.Data.DataSet DtSet;
                System.Data.OleDb.OleDbDataAdapter MyCommand;
                MyConnection = new 
   System.Data.OleDb.OleDbConnection("provider=Microsoft.Jet.OLEDB.4.0;Data 
      Source='c:\\newvbs\\examplewkb.xls';Extended Properties=Excel 8.0;");
                MyCommand = new System.Data.OleDb.OleDbDataAdapter("select 
  * from [Sheet1$]", MyConnection);
                MyCommand.TableMappings.Add("Table", "TestTable");
                DtSet = new System.Data.DataSet();
                MyCommand.Fill(DtSet);
                dataGridView2 .DataSource = DtSet.Tables[0];
               //MyConnection.Close();
           StreamWriter serialWriter;
            serialWriter = new StreamWriter("serialXML.xml");
            XmlSerializer xmlWriter = new XmlSerializer(DtSet.GetType());
            xmlWriter.Serialize(serialWriter, DtSet);
            serialWriter.Close();
            DtSet.Clear();
            dataGridView2.DataSource = DtSet.Tables[0];
            MyConnection.Close();
        } 
            catch (Exception ex)
            {
                MessageBox.Show(ex.ToString());
            }
        }

    private void dataGridView2_CellContentClick(object sender, 
    DataGridViewCellEventArgs e)
    {

    }
  }
  }
...