作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何在列表中执行此操作 (user.image = plugins.LoadImage(user.Image))
LoadImage 是以 BitmapImage 形式返回图像的函数
var query = (
from user in chatDBContext.tbl_User
select new
{
user.FirstName, user.LastName, user.Gender, user.Email,
user.DoB, user.Address, user.City, user.State,user.Country,
user.Quote, user.username, (user.image = plugins.LoadImage(user.Image))
}
).ToList();
最佳答案
请考虑 plugins.LoadImage(user.Image))
无法在 linq2sql(或 EntityFramework)上下文中执行。
因此:首先执行查询,获取内存中的对象(例如,您可以通过调用 .ToList()
或 .ToArray()
来实现),然后检索图像。
// database oriented query
var query = from user in chatDBContext.tbl_User
select user;
// take objects in memory THEN retrieve images
var objects = query.ToList().Select(user => new
{
user.FirstName, user.LastName, user.Gender, user.Email,
user.DoB, user.Address, user.City, user.State,
user.Quote, user.username, image = plugins.LoadImage(user.Image)
});
考虑到您可以避免重复所有 user
字段,只需选择整个对象而不是所有单个属性:
var objects = query.ToList().Select(user => new
{
user, image = plugins.LoadImage(user.Image))
});
用法:
foreach (var obj in objects)
{
Console.WriteLine(obj.user.FirstName);
Console.WriteLine(obj.user.LastName);
// and so on all user properties
Console.WriteLine(obj.image.Height); // just example
}
编辑(澄清)
在您的源代码中有 2 个不同的问题:
user.image
属性(我不知道您的 User
中是否有任何名为 image
的属性类):你不能对匿名对象构造函数进行赋值。相反,就像我的示例或其他答案示例一样,您应该在匿名对象初始值设定项中声明一个 image
属性。new { user.image = plugins.LoadImage(user.Image) }
应该变成
new { image = plugins.LoadImage(user.Image) }
Convert.ToInt32()
、.ToString()
等有关您可以执行 到 linq2sql 查询的代码的更多信息,请查看 here ,否则为 EntityFramework here
关于c# - 如何在 Linq 输出列表中将字节数组转换为图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35692787/
我是一名优秀的程序员,十分优秀!