首页 / C# / c# – 像VLOOKUP之类的东西
c# – 像VLOOKUP之类的东西
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 像VLOOKUP之类的东西,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含822字,纯文字阅读大概需要2分钟。
内容图文
![c# – 像VLOOKUP之类的东西](/upload/InfoBanner/zyjiaocheng/803/648fc9d182fc4086b3ad97e6c1ba201a.jpg)
我正在尝试合并两个不同对象的列表,其中特定字段(employeeID)等于另一个列表中的特定字段[0,0].我的代码看起来像这样:
int i = Users.Count() - 1;
int i2 = oracleQuery.Count() - 1;
for (int c = 0; c <= i; c++)
{
for (int d = 0; d <= i2; d++)
{
if (Users[c].getEmployeeID().ToString() == oracleQuery[d][0,0].ToString())
{
Users[c].setIDMStatus(oracleQuery[d][0,1].ToString());
}
}
}
这有效…但它看起来效率不高.有关更高效代码的任何建议,最终将导致包含oracleQuery列表中的新信息的Users列表?
解决方法:
您可以使用Enumerable.Join的连接:
var matches = Users.Join(oracleQuery,
u => u.getEmployeeId().ToString(),
oq => oq[0,0].ToString(),
(u,oc) => new { User = u, Status = oc[0,1].ToString() });
foreach(var match in matches)
match.User.setIDMStatus(match.Status);
请注意,如果getEmployeeId()和oracleQuery的[0,0]元素属于同一类型,则可以消除ToString()调用.
内容总结
以上是互联网集市为您收集整理的c# – 像VLOOKUP之类的东西全部内容,希望文章能够帮你解决c# – 像VLOOKUP之类的东西所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。
来源:【匿名】