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# WPF - Prism 学习篇:搭建项目(一)
c#·wpf·prism
椰椰椰耶5 小时前
【MyBatis】XML实现,配置方法和增、删、改、查
xml·oracle·mybatis
小码编匠7 小时前
WPF 自定义分页控件,可通过样式模板修改外观
后端·c#·.net
CoderPractice8 小时前
C#控制台小项目-飞行棋
开发语言·c#·小游戏·飞行棋
ajassi20009 小时前
开源 C# .net mvc 开发(八)IIS Express轻量化Web服务器的配置和使用
linux·开源·c#·mvc·.net
19H14 小时前
Flink-Source算子状态恢复分析
c#·linq
枯萎穿心攻击16 小时前
响应式编程入门教程第二节:构建 ObservableProperty<T> — 封装 ReactiveProperty 的高级用法
开发语言·unity·c#·游戏引擎
Eiceblue18 小时前
【免费.NET方案】CSV到PDF与DataTable的快速转换
开发语言·pdf·c#·.net
旷世奇才李先生21 小时前
XML Schema 安装使用教程
xml