问题描述
让我说我有一个物品清单:
TEST1 -- 99,56$ -- 25 PCS -- 10:56
TEST2 -- 56,57$ -- 57 PCS -- 11:01
TEST3 -- 56,57$ -- 43 PCS -- 11:06
TEST4 -- 56,57$ -- 59 PCS -- 11:33
TEST3 -- 56,57$ -- 43 PCS -- 11:06
TEST3 -- 56,57$ -- 43 PCS -- 11:06
TEST1 -- 58,98$ -- 25 PCS -- 11:45
我只想将NAME值(NAME值是TEST所在的第一部分)和PCS值相同的重复项放到一个新列表中,所以我想要的新列表输出将是:>
TEST3 -- 56,57$ -- 43 PCS -- 11:06
TEST1 -- 99,56$ -- 25 PCS -- 10:56
TEST1 -- 58,98$ -- 25 PCS -- 11:45
我的当前代码:
namespace Test
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click_1(object sender,EventArgs e)
{
List<string> listwithbuys = new List<string>(new string[] {
"TEST1 -- 99,56$ -- 25 PCS -- 10:56","TEST2 -- 56,57$ -- 57 PCS -- 11:01","TEST3 -- 56,57$ -- 43 PCS -- 11:06","TEST4 -- 56,57$ -- 59 PCS -- 11:33","TEST1 -- 58,98$ -- 25 PCS -- 11:45" });
List<String> duplicates = listwithbuys.GroupBy(x => x)
.Where(g => g.Count() > 1)
.Select(g => g.Key)
.ToList();
listbox1.DataSource = duplicates;
}
}
}
上面的代码会打印出我
TEST3 -- 56,57$ -- 43 PCS -- 11:06
这不是我的目标,就像我说的,我只希望它给我提供名称和PCS值相同的重复项。感谢任何尝试提供帮助的人:)
解决方法
能否请您尝试使用此代码,如果有任何疑问,请告诉我。
List<string> listwithbuys = new List<string>(new string[] {
"TEST1 -- 99,56$ -- 25 PCS -- 10:56","TEST2 -- 56,57$ -- 57 PCS -- 11:01","TEST3 -- 56,57$ -- 43 PCS -- 11:06","TEST4 -- 56,57$ -- 59 PCS -- 11:33","TEST1 -- 58,98$ -- 25 PCS -- 11:45" });
List<String> duplicates = listwithbuys.GroupBy(x => new { Name = x.Split(new string[] { " -- " },StringSplitOptions.None)[0],PCS = x.Split(new string[] { " -- " },StringSplitOptions.None)[2] })
.Where(g => g.Count() > 1)
.Select(g => g.LastOrDefault())
.ToList();