草庐IT

c# - LINQ Order By Descending with Null Values on Bottom

这个问题在这里已经有了答案:LINQorderbynullcolumnwhereorderisascendingandnullsshouldbelast(10个答案)关闭8年前。我有这样的表达:troubletickets=db.ServiceTickets.Include(t=>t.Company).Include(t=>t.UserProfile);troubletickets.OrderByDescending(t=>t.UserProfile!=null?t.UserProfile.FirstName:"ZZZ");我必须检查UserProfile是否为null,因为如果不这样

c# - 为 LINQ/Lambda 创建 OrderBy 表达式

我正在创建一个使用Lambda/LINQ进行动态where和orderby的概念验证。以下代码适用于where表达式,但我无法弄清楚如何通过表达式创建订单。对于这个例子,如果可能的话我想保持简单;我宁愿不编写修改表达式树的代码。voidMain(){DateTimeproductSince=DateTime.UtcNow.Subtract(newTimeSpan(1,30,0));Expression>filter=d=>d.CreatedDate>productSince&&d.Priceproducts=GetProducts(filter,Products);Console.Wr

c# - LINQ 和 XDocument : How to create XML file?

我在C#中有一个三个列表,变量名称是l_lstData1、l_lstData2、l_lstData3。文件结构为3个List的取值如下:l_lstData1[0]="India";l_lstData1[1]="chennai";l_lstData1[2]="hyderabad";l_lstData1[3]="calcutta";所以上面的XML(element:Data)的level属性的值为="2"。l_lstData2[0]="vijayawada";l_lstData2[1]="cochin";所以上面的XML(element:Data)的level属性的值为="1"。l_lst

c# - LINQ vs Lambda vs 匿名方法 vs 委托(delegate)

谁能解释一下LINQ、Lambda、匿名方法和委托(delegate)的含义?这三者有何不同?一个可以替换另一个吗?我在谷歌搜索时没有得到任何具体答案 最佳答案 LINQ是一个宽泛的技术名称,涵盖了.NET3.5的大部分内容和C#3.0的变化;“用语言查询”等等。委托(delegate)相当于函数指针;一个“方法句柄”作为一个对象,如果你愿意的话,即Funcadd=(a,b)=>a+b;是一种编写我随后可以调用的委托(delegate)的方法。委托(delegate)还支持事件和其他回调方法。匿名方法是用于创建委托(delegate

c# - 我应该关注 linq 查询中的 "access to modified closure"吗?

我有一个显示错误的linq查询:如果集合的源是一个linq查询,每当我尝试访问我正在迭代的变量时,我都会看到这个错误。我想这个错误只是告诉我变量可能会改变,或者类似的东西? 最佳答案 此错误告诉您查询中对pubConfig的引用将使用pubConfig的值在评估查询时,而不是在您定义它并将其存储在pubConfigSettings中时。实际上,如果“当场”评估查询就没问题。如果您保留它供以后评估,而pubConfig的值在此期间发生变化,您将遇到意想不到的结果。 关于c#-我应该关注li

c# - 使用 LINQ 将 Dictionary<String,Int> 转换为 Dictionary<String,SomeEnum>?

我正试图找到一个LINQoneliner,它接受一个Dictionary并返回一个Dictionary....这可能不可能,但会很好。有什么建议吗?编辑:ToDictionary()是显而易见的选择,但你们中有人实际尝试过吗?在Dictionary上它的工作方式与在Enumerable上的工作方式不同...您不能将键和值传递给它。编辑#2:哦,我在这行上面有一个错字,导致编译器搞砸了。一切顺利。 最佳答案 它通过简单的转换直接工作。Dictionaryinput=newDictionary();//TransforminputDic

c# - 使用 LINQ 对列表进行排序,除了一个条目

我想订购一个字符串列表,但列表中的一个字符串应始终位于开头且未排序。使用LINQ执行此操作的最简单方法是什么?//shouldbeorderedin:first,a,b,u,z:Listl={"z","u","first","b","a"};LINQ中没有prepend方法之类的,是吗? 最佳答案 l=l.OrderBy(i=>i!="first").ThenBy(i=>i).ToList();这里的技巧是根据所讨论的商品是否是您的特殊商品来排序,然后像往常一样根据您的商品排序。既然你说你想要排序列表(使用linq),请不要忘记将查

c# - Linq 除了只考虑一个属性

我有两个对象列表。Listobj1=newList();Listobj2=newList();我想这样做:obj2=obj2.Except(obj1).ToList();但是,通过阅读与我的类似的其他问题,我了解到除非我覆盖Equals,否则这是行不通的。我不想那样做,但是obj2和obj1都有一个字符串属性,足以判断它们是否相等。如果obj2.StringProperty等同于obj1.StringProperty那么可以认为两者相等。有什么方法可以使用Except,但只使用字符串属性进行比较? 最佳答案 Except方法要求所涉

c# - 使用 LINQ 时,&& 和多个 where 子句有什么区别?

我是LINQ的新手,昨天发现你可以有多个where子句,例如:varitems=fromobjectinobjectListwhereobject.value110selectobject;或者你可以这样写:varitems=fromobjectinobjectListwhereobject.value110selectobject;两者有什么区别? 最佳答案 第一个会被翻译成:objectList.Where(o=>o.value1o.value2>10)而第二个将翻译成:objectList.Where(o=>o.value11

c# - 如何使用 LINQ 从 DataTable 中删除行?

我有以下代码从DataTable中删除行:varrows=dTable.Select("col1='ali'");foreach(varrowinrows)row.Delete();上面的代码工作正常。如何将此代码转换为LINQ? 最佳答案 LINQ不用于删除或修改-它用于查询数据。使用LINQ,您可以选择应删除的数据,然后手动删除这些数据(例如,在foreach循环中或使用ForEach列表扩展):varquery=dTable.AsEnumerable().Where(r=>r.Field("col1")=="ali");for