[英]LINQ to XML LIKE clause
鑒於以下XML
<?xml version="1.0"?>
<Message>
<ArrayOfStock xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Stock>
<StockID>9cddb639-25ee-4415-be07-3109e5ae9883</StockID>
<Description>Stock Item 0</Description>
</Stock>
<Stock>
<StockID>f89f02f9-b359-48c8-8d2f-3a950837f4fb</StockID>
<Description>Stock Item 1</Description>
</Stock>
<Stock>
<StockID>3338ec80-f59e-4979-a04c-f7d52e386bb7</StockID>
<Description>Stock Item 2</Description>
</Stock>
</ArrayOfStock>
</Message>
有沒有更好/更正確的方法可以返回Message的子級,而子級名稱以“ ArrayOf”開頭,然后返回?
IEnumerable<XElement> array = from arrayOfX
in document.Root.Elements()
where arrayOfX.Name.ToString().IndexOf("ArrayOf") > -1
select arrayOfX;
PS:這對於邊緣情況也有問題,其中IndexOf()將為String.Empty值返回0。 (盡管不確定在格式正確的XML中是否真的可行-不要以為是嗎?)
返回建模xml結構的對象的更好方法? 是。 創建一個對xml結構建模的類,並按如下方式序列化xml:
[XmlRootAttribute("ArrayOfStocks")]
public class Stocks
{
[XmlArrayItem(typeof(Stock))]
public Stock[] Stocks { get; set; }
}
public class Stock
{
public StockID { get; set; }
public Description { get; set; }
}
public class Message
{
public Stocks { get; set; }
public static Message Load( string xml )
{
var deserializer = new XmlSerializer( typeof( Stocks ) );
Stocks stocks = null;
using( TextReader textReader = new StringReader( data ) )
{
stocks = (Stocks)deserializer.Deserialize( textReader );
}
return stocks;
}
}
然后,您可以通過以下方式訪問一系列股票:
var message = Message.Load( "<xml>" );
foreach( var stock in message.Stocks )
{
Console.WriteLine( stock );
}
然后,在“邊緣情況”下,您不必擔心。 股票數組將被清空。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.