Mec*_*eer 4 vb.net list duplicates
如何删除我的重复项List(Of String)?我假设它可以与 一起使用List(Of T).Distinct,但我的结果并非如此。我究竟做错了什么?或者我必须更改什么才能删除List(Of T).
我在万维网上读过一些关于散列的东西,但我认为这不是必要的。
这是我生成列表的代码(适用于 Autodesk Inventor)。
Private Function CountCylinders(ByVal oDef As AssemblyComponentDefinition) As Integer
' Lets list all cylinder segments found in the assembly
' we will need the document name to do this.
' the initial value is nothing, if, after counting
' this is still the case, there are no cylinders.
Dim oList As New List(Of String)
' Loop through all of the occurences found in the assembly
For Each oOccurrence As ComponentOccurrence In oDef.Occurrences
' Get the occurence document
Dim oOccurenceDocument As Document
oOccurenceDocument = oOccurrence.Definition.Document
' Check if the occurence document name contains cylinder
If oOccurenceDocument.FullFileName.Contains("Cylinder") Then
' Get the cylinder filename
Dim oCylinder As String
oCylinder = oOccurenceDocument.FullFileName
' Get the filename w/o extension
oCylinder = IO.Path.GetFileNameWithoutExtension(oCylinder)
' Remove the segment mark.
oCylinder = oCylinder.Remove(oCylinder.LastIndexOf("_"), oCylinder.Length - oCylinder.LastIndexOf("_"))
oList.Add(oCylinder)
Debug.Print("add : " & oCylinder)
End If
Next
' Delete the duplicates in the list
oList.Distinct()
' TODO: can be removed.
Debug.Print("Total number of cylinders = " & oList.Count)
' Return the number of cylinders
CountCylinders = oList.Count
End Function
Run Code Online (Sandbox Code Playgroud)
这是我的代码调试输出:
add : Cylinder_1
add : Cylinder_2
add : Cylinder_2
add : Cylinder_2
add : Cylinder_2
add : Cylinder_2
add : Cylinder_7
Total number of cylinders = 7
Run Code Online (Sandbox Code Playgroud)
小智 7
由于 dotnetperls.com VB.NET Remove Duplicates From List,这就是您正在寻找的答案
ListOfString.Distinct().ToList
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11200 次 |
| 最近记录: |