<?xml version="1.0" encoding="utf-8"?>
<Patients>
<Patients_virtue ID = "001">
<Last_Name>jay </Last_Name>
<First_Name>hoho </First_Name>
<MI>0091 </MI>
<Creation_Date>20091220 </Creation_Date>
<Patient_ID>100 </Patient_ID>
</Patients_virtue>
<Patients_virtue ID = "002">
<Last_Name>LiLi </Last_Name>
<First_Name>ccc </First_Name>
<MI>1015 </MI>
<Creation_Date>20091221 </Creation_Date>
<Patient_ID>101 </Patient_ID>
</Patients_virtue>
<Patients_virtue ID = "003">
<Last_Name>suzuki </Last_Name>
<First_Name>tanaka </First_Name>
<MI>1231 </MI>
<Creation_Date>20091222 </Creation_Date>
<Patient_ID>110 </Patient_ID>
</Patients_virtue>
</Patients> 上面的xml文件中有 3个病人的信息 我想通过调用一个函数依次取出每个病人的信息 ,每次调用都取出一个病人的信息,创建一个病人的对象 并把 取出的信息赋给 对象的成员变量。 根据xml文件提示 我需要循环调用3次函数 取出这3个病人的信息 ,分别赋给 3给对象的 成员变量。
<Patients>
<Patients_virtue ID = "001">
<Last_Name>jay </Last_Name>
<First_Name>hoho </First_Name>
<MI>0091 </MI>
<Creation_Date>20091220 </Creation_Date>
<Patient_ID>100 </Patient_ID>
</Patients_virtue>
<Patients_virtue ID = "002">
<Last_Name>LiLi </Last_Name>
<First_Name>ccc </First_Name>
<MI>1015 </MI>
<Creation_Date>20091221 </Creation_Date>
<Patient_ID>101 </Patient_ID>
</Patients_virtue>
<Patients_virtue ID = "003">
<Last_Name>suzuki </Last_Name>
<First_Name>tanaka </First_Name>
<MI>1231 </MI>
<Creation_Date>20091222 </Creation_Date>
<Patient_ID>110 </Patient_ID>
</Patients_virtue>
</Patients> 上面的xml文件中有 3个病人的信息 我想通过调用一个函数依次取出每个病人的信息 ,每次调用都取出一个病人的信息,创建一个病人的对象 并把 取出的信息赋给 对象的成员变量。 根据xml文件提示 我需要循环调用3次函数 取出这3个病人的信息 ,分别赋给 3给对象的 成员变量。
解决方案 »
- Datagridview如何控制单元格焦点
- 求助关于ado.net读取备注字段时只取得了255个字符长度的问题
- sql server函数转换成c#函数
- 我有一个treeview,里面我直接增加了节点“aa”和"bb",在我的数据库里有aa 和bb 两个字段,我想从数据库里读出aa 和bb 的个数显示在aa和bb的后面,就像aa(1),bb(3)的形势?
- get 和 set 属性对的问题
- 如何测试当前是否有子窗体打开
- 超简单C#的OfficeCodeBehind问题,100分求助
- MDI的应用,主窗口怎才样保存子窗口的内容(请大家帮忙
- 请问如何才能做到象google那样的插件安装到IE中,有没有相关的资料???
- 怎么样用C#在WEB页上画图形?
- 这个调用打开FORM的方法应该怎么修改?
- C# DataTable 用法
参考这个吧
ds.ReadXml("xml文件路径");
xmldocment doc=new xmldocment();
doc.load("xxx.xml");
xmlnode node=doc.docmentelement.selectsinglenode("//Patients");
for(int i=0;i<node.children.cout;i++)
{
_LastName=node.children[i][0].innerText.value;
_FirstName=node.children[i][1].innerText.value;
}非常重要的xpath语法
选取节点
XPath 使用路径表达式在 XML 文档中选取节点。节点是通过沿着路径或者 step 来选取的。 下面列出了最有用的路径表达式:
表达式 描述
nodename 选取此节点的所有子节点
/ 从根节点选取
// 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
. 选取当前节点
.. 选取当前节点的父节点
@ 选取属性 实例
在下面的表格中,我们已列出了一些路径表达式以及表达式的结果: 路径表达式 结果
bookstore 选取 bookstore 元素的所有子节点
/bookstore 选取根元素 bookstore 注释:假如路径起始于正斜杠( / ),则此路径始终代表到某元素的绝对路径! bookstore/book 选取所有属于 bookstore 的子元素的 book 元素。
//book 选取所有 book 子元素,而不管它们在文档中的位置。
bookstore//book 选择所有属于 bookstore 元素的后代的 book 元素,而不管它们位于 bookstore 之下的什么位置。
//@lang 选取所有名为 lang 的属性。
谓语(Predicates)
谓语用来查找某个特定的节点或者包含某个指定的值的节点。 谓语被嵌在方括号中。 实例
在下面的表格中,我们列出了带有谓语的一些路径表达式,以及表达式的结果: 路径表达式 结果
/bookstore/book[1] 选取属于 bookstore 子元素的第一个 book 元素。
/bookstore/book[last()] 选取属于 bookstore 子元素的最后一个 book 元素。
/bookstore/book[last()-1] 选取属于 bookstore 子元素的倒数第二个 book 元素。
/bookstore/book[position() <3] 选取最前面的两个属于 bookstore 元素的子元素的 book 元素。
//title[@lang] 选取所有拥有名为 lang 的属性的 title 元素。
//title[@lang='eng'] 选取所有 title 元素,且这些元素拥有值为 eng 的 lang 属性。
/bookstore/book[price>35.00] 选取所有 bookstore 元素的 book 元素,且其中的 price 元素的值须大于 35.00。
/bookstore/book[price>35.00]/title 选取所有 bookstore 元素中的 book 元素的 title 元素,且其中的 price 元素的值须大于 35.00。
选取未知节点
XPath 通配符可用来选取未知的 XML 元素。 通配符 描述
* 匹配任何元素节点
@* 匹配任何属性节点
node() 匹配任何类型的节点 实例
在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果: 路径表达式 结果
/bookstore/* 选取 bookstore 元素的所有子节点
//* 选取文档中的所有元素
//title[@*] 选取所有带有属性的 title 元素。
选取若干路径
通过在路径表达式中使用“|”运算符,您可以选取若干个路径。 实例
在下面的表格中,我们列出了一些路径表达式,以及这些表达式的结果: 路径表达式 结果
//book/title | //book/price 选取所有 book 元素的 title 和 price 元素。
//title | //price 选取所有文档中的 title 和 price 元素。
/bookstore/book/title | //price 选取所有属于 bookstore 元素的 book 元素的 title 元素,以及文档中所有的 price 元素。
<ArrayOfPatients_virtue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Patients_virtue ID="003">
<Last_Name>ln1</Last_Name>
<First_Name>test1</First_Name>
<MI>aaa</MI>
<Creation_Date>2009-12-22T12:44:10.2373046+08:00</Creation_Date>
<Patient_ID>0231</Patient_ID>
</Patients_virtue>
<Patients_virtue ID="004">
<Last_Name>ln2</Last_Name>
<First_Name>test2</First_Name>
<MI>aaa2</MI>
<Creation_Date>2009-12-22T12:44:10.2392578+08:00</Creation_Date>
<Patient_ID>0232</Patient_ID>
</Patients_virtue>
<Patients_virtue ID="005">
<Last_Name>ln3</Last_Name>
<First_Name>test3</First_Name>
<MI>aabb</MI>
<Creation_Date>2009-12-22T12:44:10.2392578+08:00</Creation_Date>
<Patient_ID>0233</Patient_ID>
</Patients_virtue>
</ArrayOfPatients_virtue>//----------这个文档 通过了XML序列化的测试,可以读写,因为这是个集合对象所以按MSDN文档要求,需要先定义两个类,一个是集合元素类,一个是,集合类,MSDN要求 继承集合类,来实现它以完成序列的要求象这样定义:
元素类:
public class Patients_virtue {
[XmlAttribute]
public string ID { get; set; }
[XmlElementAttribute]
public string Last_Name { get; set; }
[XmlElementAttribute]
public string First_Name { get; set; }
[XmlElementAttribute]
public string MI { get; set; }
[XmlElementAttribute]
public DateTime Creation_Date { get; set; }
[XmlElementAttribute]
public string Patient_ID { get; set; }
}
集合类:
public class mc:ICollection {
List<Patients_virtue> pvl;
public mc() {
this.pvl = new List<Patients_virtue>();
}
#region ICollection 成员 public void CopyTo(Array array , int index) {
this.pvl.CopyTo((Patients_virtue[])array);
} public int Count {
get { return this.pvl.Count; }
} public bool IsSynchronized {
get { return false; }
} public object SyncRoot {
get { return this; }
} #endregion #region IEnumerable 成员 public IEnumerator GetEnumerator() {
throw new NotImplementedException();
} #endregion
public void Add(Patients_virtue pv) {
this.pvl.Add(pv);
}
public Patients_virtue this[int index] {
get { return this.pvl[index]; }
}
}
//
测试:
public void Run() {
string path = "testresult.xml";
XmlSerializer xs = new XmlSerializer(typeof(mc));
XmlReader xr = XmlReader.Create(path); var v = xs.Deserialize(xr);
//mc m = new mc();
//m.Add(new Patients_virtue() { First_Name = "test1" , Last_Name = "ln1" , MI = "aaa" , ID = "003" , Creation_Date = DateTime.Now , Patient_ID = "0231" });
//m.Add(new Patients_virtue() { First_Name = "test2" , Last_Name = "ln2" , MI = "aaa2" , ID = "004" , Creation_Date = DateTime.Now , Patient_ID = "0232" });
//m.Add(new Patients_virtue() { First_Name = "test3" , Last_Name = "ln3" , MI = "aabb" , ID = "005" , Creation_Date = DateTime.Now , Patient_ID = "0233" });
//using (StreamWriter sw=new StreamWriter(File.Open(path,FileMode.OpenOrCreate,FileAccess.Write))) {
// xs.Serialize(sw , m);
//}
}
//测试的Run方法中的下半部分注释的是 序列化到XML文档,而上半部分是 从XML读取,经测试
可以方便的读出集合对象。