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();

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

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

}

}

相关推荐
小猪快跑爱摄影28 分钟前
【AutoCad 2025】【C#】零基础教程(三)——获取选中的 Entity 插件 =》 初识 Entity 派生类
c#·autocad
czhc11400756632 小时前
c#w 1214
开发语言·c#
用户298698530142 小时前
C# 中如何从 URL 下载 Word 文档:基于 Spire.Doc 的高效解决方案
后端·c#·.net
wangbing11252 小时前
将swagger在线文档转为word
microsoft·c#·word
mangge083 小时前
定时刷新已经登录过的网页c#
c#
拾忆,想起3 小时前
Dubbo多协议暴露完全指南:让一个服务同时支持多种通信方式
xml·微服务·性能优化·架构·dubbo
走错路的程序员4 小时前
C语言单片机与C#上位机之间传递大量参数比较好的实践方案
c语言·单片机·c#
辜月廿七5 小时前
C#字符串相关知识
c#
波波0075 小时前
使用.NET 四步玩转 AI 绘图|不用Python、不买显卡
开发语言·c#·.net
唐青枫6 小时前
深入理解 C#.NET 运算符重载:语法、设计原则与最佳实践
c#·.net