惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Recorded Future
Recorded Future
Microsoft Security Blog
Microsoft Security Blog
Recent Commits to openclaw:main
Recent Commits to openclaw:main
The Register - Security
The Register - Security
The GitHub Blog
The GitHub Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
人人都是产品经理
人人都是产品经理
量子位
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
有赞技术团队
有赞技术团队
Stack Overflow Blog
Stack Overflow Blog
H
Help Net Security
Apple Machine Learning Research
Apple Machine Learning Research
The Cloudflare Blog
B
Blog RSS Feed
小众软件
小众软件
博客园 - 叶小钗
H
Hackread – Cybersecurity News, Data Breaches, AI and More
博客园 - 聂微东
博客园_首页
B
Blog
雷峰网
雷峰网
S
SegmentFault 最新的问题
N
Netflix TechBlog - Medium
D
Docker
博客园 - 司徒正美
博客园 - 【当耐特】
大猫的无限游戏
大猫的无限游戏
博客园 - Franky
MongoDB | Blog
MongoDB | Blog
U
Unit 42
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
腾讯CDC
F
Fortinet All Blogs
aimingoo的专栏
aimingoo的专栏
Martin Fowler
Martin Fowler
Jina AI
Jina AI
WordPress大学
WordPress大学
D
DataBreaches.Net
V
V2EX
V
Visual Studio Blog
Know Your Adversary
Know Your Adversary
P
Privacy & Cybersecurity Law Blog
F
Full Disclosure
G
Google Developers Blog
Engineering at Meta
Engineering at Meta
The Hacker News
The Hacker News
Security Archives - TechRepublic
Security Archives - TechRepublic
IT之家
IT之家
P
Privacy International News Feed

博客园 - nestea

Method 'Post' of object 'IOWSPostData' failed(方法'POST'作用于对象'IOWSPostData'时失败) 用Win XP安装盘修复系统文件 手机呼叫流程 XML配置字符串中特殊字符的处理 - nestea - 博客园 关于BackgroundWorker的使用 分布式缓存系统Memcached简介与实践[转] web应用程序中使用MemcachedClient (转载) 一些很酷的.Net技巧(转载) sql server中的decimal或者numeric的精度问题 (转载) 使用BackgroundWorker组件进行异步操作编程(转载) 操作DataTable中动态的行,一点收集整理资料。 预处理命令之条件编译(转) 数字的进制(2进制,8进制,16进制) C#中父窗口和子窗口之间实现控件互操作 (转载) 开放式并发冲突检测的四种方法 MDX 中的重要概念 (MDX) 实用工具-文件夹实时同步工具 (群集服务器拷贝) 用windows 2003建立VPN 连接(转载) - nestea Windows 2003下VPN服务器架设攻略 (转载) - nestea
xml转换成DataTable - nestea - 博客园
nestea · 2009-05-21 · via 博客园 - nestea

一、使用 XML定义DataTable构架

<?xml version="1.0" encoding="utf-8" ?>
<root>
  <url>http://10.168.68.227:8080/AlarmInfoService/services/AlarmInfoService</url>
  <columns>
    <column cname="FP0" ctype="System.Decimal"></column>
    <column cname="FP1" ctype="System.Decimal"></column>
    <column cname="FP2" ctype="System.Decimal"></column>
    <column cname="FP3" ctype="System.Decimal"></column>
    <column cname="TIME_STAMP" ctype="System.Int32"></column>
    <column cname="C_FP0" ctype="System.Decimal"></column>
    <column cname="C_FP1" ctype="System.Decimal"></column>
    <column cname="C_FP2" ctype="System.Decimal"></column>
    <column cname="C_FP3" ctype="System.Decimal"></column>
    <column cname="INT_ID" ctype="System.Int32"></column>

    </columns>
</root>

DataTable dt = new DataTable();

 XmlDocument doc = new XmlDocument();
            string pathurl = System.IO.Directory.GetCurrentDirectory().Replace("Bin\\bin", "") + @"AlarmCreateDataTableConfig.xml";
            doc.Load(pathurl);
            XmlNodeList xml = doc.GetElementsByTagName("column");
            for (int i = 0; i < xml.Count; i++)
            {
                string dataName = xml.Item(i).Attributes["cname"].Value;
                string dataType=xml.Item(i).Attributes["ctype"].Value;
                dt.Columns.Add(new DataColumn(dataName, Type.GetType(dataType)));
            }

二、另外一种运用方法:

 using   System;  
  using   System.Data;  
  using   System.Collections;  
  using   System.Xml;  
  using   System.IO;  
  using   System.Text;  
   
  namespace   ConsoleTest  
  {  
  ///   <summary>  
  ///   ZZConsole   的摘要说明。  
  ///   </summary>  
  public   class   ZZConsole  
  {  
  [STAThread]  
  static   void   Main(string[]   args)  
  {  
   
  XmlDocument   xdoc=   new   XmlDocument();  
  xdoc.Load(@"d:\test.xml");  
  DataSet   ds   =   CreatDataSet();  
  XmlNodeList   xList   =   xdoc.SelectNodes("//Item");  
  foreach(XmlNode   xNode   in   xList)  
  {  
  DataRow   dr   =   ds.Tables["Items"].NewRow();  
  dr["Item"]   =   xNode.Attributes["Name"].Value;  
  ds.Tables["Items"].Rows.Add(dr);  
  }  
  foreach(DataRow   dr   in   ds.Tables["Items"].Rows)  
  {  
  Console.WriteLine(dr["Item"].ToString());  
  }  
  Console.ReadLine();  
  }  
  public   static   DataSet   CreatDataSet()  
  {  
  DataSet   ds   =   new   DataSet();  
  DataTable   dt   =   new   DataTable("Items");  
  DataColumn   dc   =   new   DataColumn("Item",typeof(string));  
  dt.Columns.Add(dc);  
  ds.Tables.Add(dt);  
  return   ds;  
  }  
  }  
  }  
  =======================================================  
  <?xml   version="1.0"   encoding="utf-8"   ?>  
  <Root>  
          <Class   Name="1">  
                  <Item   Name="Item11"/>  
                  <Item   Name="Item12"/>  
                  <Item   Name="Item13"/>  
                  <Item   Name="Item14"/>  
          </Class>  
          <Class   Name="2">  
                  <Item   Name="Item21"/>  
                  <Item   Name="Item22"/>  
                  <Item   Name="Item23"/>  
                  <Item   Name="Item24"/>  
          </Class>  
  </Root>