[ 来源:www.it55.com | 作者: | 时间:2007-07-15 | 收藏 | 推荐 ] 【大 中 小】
在.net平台下,XML处理技术有几种方式,主要分为2部分,写XML和读XML。 免费资源www.it55.com
1 写XML,.net framework提供XMLTextWriter类来操作,把数据写入一个XML文件,代码如下: 45398 www.it55.com it55学习IT知识,享受IT生活 4dfkjn
static void WriteXMLbyXmlWriter(XmlWriter writer, string symbol, double price, double change, long volume)
{
writer.WriteStartElement("Stock");
writer.WriteAttributeString("Symbol", symbol);
writer.WriteElementString("Price", XmlConvert.ToString(price));
writer.WriteElementString("Change", XmlConvert.ToString(change));
writer.WriteElementString("Volume", XmlConvert.ToString(volume));
writer.WriteEndElement();
}
http://www.it55.com/
protected void CreateXMLFileButton_Click(object sender, System.EventArgs e)
{
// 创建一个表示所要生成的XML文件路径的字符串。如果该路径指向NTFS分区,则需要相关的访问权限。
string filename = XMLFilePathTextBox.Text;
// 创建一个写入XML数据的文件流
System.IO.FileStream myFileStream = new System.IO.FileStream(filename, System.IO.FileMode.Create);
// 使用文件流对象创建一个XmlTextWriter对象
XmlTextWriter myXmlWriter = new XmlTextWriter(myFileStream, System.Text.Encoding.Unicode);
myXmlWriter.Formatting = Formatting.Indented;
try
{
// 使用WriteXMLbyXmlWriter方法把数据写入XmlTextWriter对象中
IT资讯之家 www.it55.com
// 创建XmlDocument类的实例
XmlDocument doc = new XmlDocument();
ArrayList NodeValues = new ArrayList();
// 把people.xml文件读入内存,形成一个DOM结构
doc.Load( Server.MapPath("people.xml") );
XmlNode root = doc.DocumentElement;
foreach( XmlNode personElement in root.ChildNodes )//root.ChildNodes获取节点的所有子节点
NodeValues.Add(personElement.FirstChild.Value);
3 使用XMLTextReader.读入ArrayList www.it55.com在线教程
XmlTextReader reader = new XmlTextReader( Server.MapPath("students.xml") );
ArrayList NodeValues = new ArrayList();
while( reader.Read() )
{
if( reader.NodeType == XmlNodeType.Element && reader.Name == "NAME" )
{
reader.Read();
NodeValues.Add( reader.Value );
}
}
it55.com
4 使用XPath
XPathDocument xpdoc = new XPathDocument( Server.MapPath("people.xml") );
XPathNavigator nav = xpdoc.CreateNavigator();
XPathExpression expr = nav.Compile("descendant::PEOPLE/PERSON");
XPathNodeIterator iterator = nav.Select(expr);
ArrayList NodeValues = new ArrayList();
IT资讯之家 www.it55.com
while (iterator.MoveNext())
NodeValues.Add(iterator.Current.ToString()); sflj www.it55.com kg^&fgd
XMLNodeListBox.DataSource = NodeValues;
XMLNodeListBox.DataBind();
5 使用xsl展示XML中的数据 vd;k;l www.it55.com rdfg
System.Xml.XmlDocument xmldoc = new System.Xml.XmlDocument();
xmldoc.Load(Server.MapPath("user.xml"));
System.Xml.Xsl.XslTransform xmltrans = new System.Xml.Xsl.XslTransform();
xmltrans.Load(Server.MapPath("user.xsl"));
Xml1.Document = xmldoc;
Xml1.Transform = xmltrans;
user.xsl: it55.com
<?xml version='1.0'?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:template match="/">
<HTML>
<BODY>
<FONT face="Verdana" size="3">
<TABLE cellspacing="5" cellpadding="1">
<TR bgcolor="#AAAAAA">
<TD class="header"><B>UserName</B></TD>
<TD class="header"><B>Name</B></TD>
<TD class="header"><B>Phone</B></TD>
<TD class="header"><B>Address</B></TD>
</TR>
<xsl:for-each select="Users/user">
<TR bgcolor="#DDDDDD">
<TD>
<xsl:value-of select="user_name"/>
</TD>
<TD>
<xsl:value-of select="true_name"/>
</TD>
<TD>
<xsl:value-of select="phone"/>
</TD>
<TD>
<xsl:value-of select="address"/>
(编辑:IT资讯之家 www.it55.com)