C#解析xml文件

1、示例

<?xml version="1.0" encoding="utf-8" standalone="no"?><DATA><ITEMS><ITEM><ID>01<ID/><CODE>0001<CODE><NAME>测试1<NAME/></ITEM><ITEM><ID>02<ID/><CODE>0002<CODE><NAME>测试2<NAME/></ITEM></ITEMS></DATA>

2、用DataTable存储

private DataTable GetDataTable(string xmlStr, string nodepath)

{

XmlDocument doc = new XmlDocument();

doc.LoadXml(xmlStr);

XmlNodeList xlist = doc.GetElementsByTagName(nodepath);

DataTable Dt = new DataTable();

DataRow Dr;

for (int i = 0; i < xlist.Count; i++)

{

Dr = Dt.NewRow();

XmlElement xe = (XmlElement)xlist.Item(i);

for (int j = 0; j < xe.Attributes.Count; j++)

{

if (!Dt.Columns.Contains(xe.Attributes[j].Name))

Dt.Columns.Add(xe.Attributes[j].Name);

Dr[xe.Attributes[j].Name] = xe.Attributes[j].Value;

}

for (int j = 0; j < xe.ChildNodes.Count; j++)

{

if (!Dt.Columns.Contains(xe.ChildNodes.Item(j).Name))

Dt.Columns.Add(xe.ChildNodes.Item(j).Name);

Dr[xe.ChildNodes.Item(j).Name] = xe.ChildNodes.Item(j).InnerText;

}

Dt.Rows.Add(Dr);

}

return Dt;

}

3、解析

string xmlfile="xml路径";

XmlDocument doc = new XmlDocument();

doc.Load(xmlfile);

string xmlData = doc.InnerXml;

DataTable table = GetDataTable(xmlData, "//ITEM");

if (table != null && table.Rows.Count > 0)

{

for (int i = 0; i < table.Rows.Count; i++)

{

DataRow row = table.Rows[i];

string id = row["ID"].ToString();

string code= row["CODE"].ToString();

string name= row["NAME"].ToString();

//将数据逐条存入数据库

//具体的存储方式根据实际情况编写代码

}

}

相关推荐
武藤一雄3 小时前
C# 异步回调与等待机制
前端·microsoft·设计模式·微软·c#·.netcore
乱蜂朝王6 小时前
使用 C# 和 ONNX Runtime 部署 PaDiM 异常检测模型
开发语言·c#
JosieBook8 小时前
【C#】VS中的 跨线程调试异常:CrossThreadMessagingException
开发语言·c#
追雨潮8 小时前
BGE-M3 多语言向量模型实战:.NET C# 从原理到落地
开发语言·c#·.net
CheerWWW10 小时前
GameFramework——Download篇
笔记·学习·unity·c#
格林威11 小时前
ZeroMQ 在视觉系统中的应用
开发语言·人工智能·数码相机·机器学习·计算机视觉·c#·视觉检测
格林威11 小时前
工业相机图像采集:如何避免多相机数据混乱
人工智能·数码相机·opencv·机器学习·计算机视觉·c#·视觉检测
武藤一雄12 小时前
C#万字详解 栈与托管堆 的底层逻辑
windows·microsoft·c#·.net·.netcore
山檐雾12 小时前
C#泛型缓存
缓存·c#
追雨潮12 小时前
内存向量检索引擎设计与实现:C# 轻量级 Milvus 替代方案
开发语言·c#·milvus