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
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值