为什么 LINQ 中的 Union 函数不删除重复条目?

2023-11-21

我正在使用 VB .NET,我知道 Union 通常按 ByRef 工作,但在 VB 中,字符串通常被视为原始数据类型。

因此,问题就在这里:

Sub Main()
    Dim firstFile, secondFile As String(), resultingFile As New StringBuilder

    firstFile = My.Computer.FileSystem.ReadAllText(My.Computer.FileSystem.SpecialDirectories.Desktop & "\1.txt").Split(vbNewLine)
    secondFile = My.Computer.FileSystem.ReadAllText(My.Computer.FileSystem.SpecialDirectories.Desktop & "\2.txt").Split(vbNewLine)

    For Each line As String In firstFile.Union(secondFile)
        resultingFile.AppendLine(line)
    Next

    My.Computer.FileSystem.WriteAllText(My.Computer.FileSystem.SpecialDirectories.Desktop & "\merged.txt", resultingFile.ToString, True)
End Sub

1.txt包含:
a
b
c
d
e

2.txt包含:
b
c
d
e
f
g
h
i
j

运行代码后,我得到:
a
b
c
d
e
b
f
g
h
i
j

对于使 Union 函数像其数学对应函数一样工作,有什么建议吗?


Linq Union确实按照您想要的方式执行。确保您的输入文件正确(例如,其中一行在换行符之前可能包含空格)或Trim()分割后的字符串?

var list1 = new[] { "a", "s", "d" };
var list2 = new[] { "d", "a", "f", "123" };
var union = list1.Union(list2);
union.Dump(); // this is a LinqPad method

In linqpad,结果是{"a", "s", "d", "f", "123" }

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为什么 LINQ 中的 Union 函数不删除重复条目? 的相关文章