以文本方式查看主题 - Foxtable(狐表) (http://foxtable.com/bbs/index.asp) -- 专家坐堂 (http://foxtable.com/bbs/list.asp?boardid=2) ---- [求助]删除重复行,相同的行应保留一行 (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=143168) |
||||
-- 作者:天一生水 -- 发布时间:2019/11/15 16:31:00 -- [求助]删除重复行,相同的行应保留一行 老师好! 当"第一列,第二列,第三列"均相同时,认定为重复行。 下列代码删除重复行时,没有保留重复行中的其中一行在数据表。 请老师看看是什么原因? 谢谢!
Dim idx As String = "-1," If count > 1 Then \'Tables("表A").filter = "_Identify not in (" & idx.trim(",") & ")" \'显示唯一行 DataTables("表A").DeleteFor("_Identify In (" & idx.trim(",") & ")") \'删除重复行 |
||||
-- 作者:有点蓝 -- 发布时间:2019/11/15 17:04:00 -- If flag Then If count > 1 Then idx &= idx_temp End If count = 1 idx_temp = "" \'\'\'\'\'\'idx_temp &= dr("_Identify") & "," Else count += 1 If pdr IsNot Nothing Then idx_temp &= dr("_Identify") & "," End If End If
|
||||
-- 作者:天一生水 -- 发布时间:2019/11/15 17:44:00 -- 老师好! 我测试还是一样,都删除了。
|
||||
-- 作者:有点蓝 -- 发布时间:2019/11/15 20:14:00 -- 去掉这一句咯 \'\'\'\'\'\'idx_temp &= dr("_Identify") & ","
|
||||
-- 作者:天一生水 -- 发布时间:2019/12/1 22:16:00 -- 蓝老师好! 如果是临时表,没有_Identify,代码怎么用? |
||||
-- 作者:有点蓝 -- 发布时间:2019/12/1 22:21:00 -- 怎么生成的临时表?如果是sql,一样可以添加_Identify。如果没有那就使用其它唯一值的列。如果都没有,请上传实例说明 |
||||
-- 作者:天一生水 -- 发布时间:2019/12/1 22:42:00 -- 谢谢蓝老师! 我做个实例,删除空行修改以后还是不行,删除重复行也请老师看一下。
|
||||
-- 作者:有点蓝 -- 发布时间:2019/12/1 23:15:00 -- Dim pdr As DataRow = Nothing Dim count As Integer = 0 Dim cs As String = e.Form.Controls("CheckedComboBox2").text Dim drs As List(of DataRow) = DataTables("去重复行").Select("", cs) pdr = drs(drs.Count - 1) Dim dr As DataRow Dim arr() As String = cs.Split(",") For i As Integer = drs.Count - 2 To 0 Step -1 dr = drs(i) Dim same As Boolean = True For Each s As String In arr If dr(s) <> pdr(s) Then same = False Exit For End If Next If same = False Then pdr = dr drs.Remove(dr) End If Next For Each dr In drs dr.Delete Next
|
||||
-- 作者:天一生水 -- 发布时间:2019/12/2 19:36:00 -- 老师好! 楼上的代码,如果没有符合条件的,会把最下面一行删除。应该怎样改一下~ 谢谢!
|
||||
-- 作者:有点蓝 -- 发布时间:2019/12/2 20:49:00 -- Dim pdr As DataRow = Nothing Dim count As Integer = 0 Dim cs As String = e.Form.Controls("CheckedComboBox2").text Dim drs As List(of DataRow) = DataTables("去重复行").Select("", cs) pdr = drs(drs.Count - 1) drs.Remove(pdr) Dim dr As DataRow Dim arr() As String = cs.Split(",") For i As Integer = drs.Count - 1 To 0 Step -1 dr = drs(i) Dim same As Boolean = True For Each s As String In arr If dr(s) <> pdr(s) Then same = False Exit For End If Next If same = False Then pdr = dr drs.Remove(dr) End If Next For Each dr In drs dr.Delete Next |