Ich habe die Datentabelle folgende:Convert Datatable in XML-Hierarchie in C#
A B C
----------
A1 B1 C1
A1 B1 C2
A1 B1 C3
A1 B2 C1
A1 B2 C2
----------
Ich habe versucht, es zu konvertieren C# im XML-Format so sein:
<Data>
<A>
<lable>A1</lable>
<B>
<lable>B1</lable>
<C>
<lable>C1</lable>
<lable>C2</lable>
<lable>C3</lable>
</C>
<lable>B2</lable>
<C>
<lable>C1</lable>
<lable>C2</lable>
</C>
</B>
</A>
</Data>
ich eine tiefe Suche tat und ich fand etwas hilfreiches online wie this. Aber das verwendet Beziehungen, und meine Daten sind nur eine Tabelle. ich auch diesen C# -Code versucht:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml.Linq;
using System.Data.SqlClient;
SqlConnection con = new SqlConnection("Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=Files;Data Source=localhost");
con.Open();
SqlCommand cmd = new SqlCommand("select * from MyTable",con);
SqlDataAdapter da = new SqlDataAdapter(cmd);
DataTable DT = new DataTable("Data");
da.Fill(DT);
dataGridView1.DataSource = DT;
con.Close();
string XML = ToXmlFormat(DT, 0);
Console.WriteLine(XML);
public string ToXmlFormat(this DataTable table, int metaIndex = 0)
{
XDocument xdoc = new XDocument(
new XElement(table.TableName,
from column in table.Columns.Cast<DataColumn>()
where column != table.Columns[metaIndex]
select new XElement(column.ColumnName,
from row in table.AsEnumerable()
select new XElement(row.Field<string>(metaIndex), row[column])
)
)
);
return xdoc.ToString();
}
Das Ergebnis war ein anderes Format, das nicht verschachteltes XML ist wie ich erklärte. see image
Wie kann ich meine Tabelle in das XML-Format konvertieren, das ich brauche?
Datentabelle, WriteXml wird es in einem Format schreiben es für sie zurück – Plutonix
Lesen braucht kein Ich habe auch versucht, dass es nur einen Knoten zurückgibt, Sie versuchen es, aber es ist falsch –