它在行中。我稍微修复了你的 xml :)
var xml = "<item attr=\"some attribute\"><description>anything</description></item>";
var ds = new DataSet();
ds.ReadXml( new StringReader( xml ), XmlReadMode.Auto );
var ia = ds.Tables[0].Rows[0].ItemArray;
var att = ia[1]; // att == "some attribute"
如果您没有架构,则可能必须检查该列以确定它是什么。
每条评论:您会看到我让它推断架构 (XmlReadMode.Auto)。它将根节点下的元素作为 Rows,然后按顺序添加属性,然后添加元素中的值。因此,例如以下 XML ...
var xml = "<items>
<item attr1='attr1' attr2='attr2'>
<description>desc1</description>
</item>
<item attr1='attr3' attr2='attr4'>
<description>desc2</description></item>
</items>";
我将得到两行(每个项目一个),其中包含 attr1、attr2 和描述的列。您可以使用模式更改它解释 XML 的方式。