var log@R_301_5962@ = from entry in xDoc.Descendants("logentry") where (entry.Element("author").Value.Tolower().Contains(matchText) || entry.Element("msg").Value.Tolower().Contains(matchText) || entry.Element("paths").Value.Tolower().Contains(matchText) || entry.Element("revision").Value.Tolower().Contains(matchText)) select new { Revision = entry.Attribute("revision").Value,Author = entry.Element("author").Value,CR = LogFormatter.FormatCR(entry.Element("msg").Value),Date = LogFormatter.FormatDate(entry.Element("date").Value),Message = LogFormatter.FormatComment(entry.Element("msg").Value),ET = LogFormatter.FormatET(entry.Element("msg").Value),MergeFrom = LogFormatter.FormatMergeFrom(entry.Element("msg").Value),Mergeto = LogFormatter.FormatMergeto(entry.Element("msg").Value) };解决方法 它实际上非常简单;
from entry in Awhere B
将(字面意思)翻译为:
A.Where(entry=>B)
和:
select C
直接翻译(以“条目”作为我们的上下文):
.Select(entry=>C)
(当它是entry =>条目时,编译器忽略了非重要的情况除外)
所以只需注入那些就完成了:
var log@R_301_5962@ = xDoc.Descendants("logentry") .Where(entry=> entry.Element("author").Value.Tolower().Contains(matchText) || entry.Element("msg").Value.Tolower().Contains(matchText) || entry.Element("paths").Value.Tolower().Contains(matchText) || entry.Element("revision").Value.Tolower().Contains(matchText)) .Select(entry=>new { Revision = entry.Attribute("revision").Value,Mergeto = LogFormatter.FormatMergeto(entry.Element("msg").Value) });总结
以上是内存溢出为你收集整理的c# – 如何将查询语法转换为方法语法全部内容,希望文章能够帮你解决c# – 如何将查询语法转换为方法语法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)