如何洗掉資料表中的多行?我想從資料表中洗掉一些行,例如,從第 10 行到第 35 行。并將更改保存到資料表中。
uj5u.com熱心網友回復:
您可以使用 LINQ 僅選擇您想要的行,并將結果復制到資料表中:
Module Module1
Function SampleDataTable() As DataTable
Dim dt As New DataTable
dt.Columns.Add("Col1", Type.GetType("System.String"))
For i = 1 To 11
Dim dr = dt.NewRow()
dr(0) = i.ToString() & ChrW(i 64)
dt.Rows.Add(dr)
Next
Return dt
End Function
Sub ShowDataTable(dt As DataTable)
For Each r As DataRow In dt.Rows
Console.WriteLine(String.Join(", ", r.ItemArray()))
Next
End Sub
Sub Main()
Dim dt = SampleDataTable()
Console.WriteLine("Before:")
ShowDataTable(dt)
' Assuming the first row is to be regarded as row number 1.
Dim firstDelete = 5
Dim lastDelete = 8
dt = dt.AsEnumerable().
Where(Function(r, i) i < firstDelete - 1 OrElse i >= lastDelete).
CopyToDataTable()
Console.WriteLine("After:")
ShowDataTable(dt)
Console.ReadLine()
End Sub
End Module
如果給Where函式提供第二個引數,它會用當前專案的索引(從 0 開始)填充它。
輸出:
Before:
1A
2B
3C
4D
5E
6F
7G
8H
9I
10J
11K
After:
1A
2B
3C
4D
9I
10J
11K
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/351527.html
標籤:网络
