[英]linq to xml empty list<string> element?
在下面的linq to xml查詢中,我有2個屬性,分別是list<string>
,DefaultValues和Values。
如果這些元素中的任何一個為空,我想將LiteValueParameter
對象的屬性設置為一個新的空列表:
Values = new List<string>();
取而代之的是,linq查詢給了我一些東西:
Values = new List<string>();
Values.Add("");
如果我的XML中有一個空元素,有什么方法可以防止將一個空項目添加到列表中?
Linq代碼:
//linq query
List<LiteValueParameter> valParams = new List<LiteValueParameter>();
valParams = (from c in doc.Descendants("Parameters").Descendants("Parameter")
where (LiteParameterType)Enum.Parse(typeof(LiteParameterType), c.Element("ParameterType").Value, true) == LiteParameterType.Value
select new LiteValueParameter()
{
Id = c.Attribute("Id").Value,
DataType = Type.GetType(c.Element("DataType").Value, true),
DefaultValues = c.Elements("DefaultValues").Select(element => element.Value).ToList(),
DisplayText = c.Element("DisplayText").Value,
IsRequired = Convert.ToBoolean(c.Element("IsRequired").Value),
MinCount = Convert.ToInt32(c.Element("MinCount").Value),
MaxCount = Convert.ToInt32(c.Element("MaxCount").Value),
MinValue = c.Element("MinValue").Value,
MaxValue = c.Element("MaxValue").Value,
ParameterName = c.Element("ParameterName").Value,
Values = c.Elements("Values").Select(element => element.Value).ToList(),
ParameterType = (LiteParameterType)Enum.Parse(typeof(LiteParameterType), c.Element("ParameterType").Value, true),
DisplayType = c.Element("DisplayType").Value
}).ToList();
XML代碼:
<Parameters>
<Parameter Id="PermissionList">
<ParameterType>Value</ParameterType>
<ParameterName>Permissions</ParameterName>
<DisplayType>ListBox</DisplayType>
<DisplayText>Permissions</DisplayText>
<IsRequired>true</IsRequired>
<MinValue />
<MaxValue />
<DefaultValues />
<Values />
<DataType>System.String</DataType>
<MinCount>1</MinCount>
<MaxCount>1</MaxCount>
</Parameter>
</Parameters>
我想您可以這樣解決:
DefaultValues = (c.Elements("DefaultValues").Count() == 1 && c.Elements("DefaultValues").First().Value == string.Empty) ? new List<string>() :
c.Elements("DefaultValues").Select(element => element.Value).ToList(),
但是,這種方法感覺很“ hacky”。 相反,我將更改您的XML以具有您查詢的DefaultValue
元素:
<DefaultValues>
<DefaultValue>Foo</DefaultValue>
</DefaultValues>
這自然得多,現在您可以像這樣編寫查詢
DefaultValues = c.Descendants("DefaultValue").Select(element => element.Value).ToList(),
如果您只有
<DefaultValues/>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.