Foxtable(狐表)用户栏目专家坐堂 → [求助]删除重复行,相同的行应保留一行


  共有2287人关注过本帖树形打印复制链接

主题:[求助]删除重复行,相同的行应保留一行

帅哥哟,离线,有人找我吗?
天一生水
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1137 积分:11224 威望:0 精华:0 注册:2017/9/26 16:30:00
[求助]删除重复行,相同的行应保留一行  发帖心情 Post By:2019/11/15 16:31:00 [只看该作者]

老师好!

当"第一列,第二列,第三列"均相同时,认定为重复行。

下列代码删除重复行时,没有保留重复行中的其中一行在数据表。

请老师看看是什么原因?

谢谢!

 

Dim idx As String = "-1,"
Dim idx_temp As String = ""
Dim pdr As DataRow = Nothing
Dim count As Integer = 0
Dim cs As String = "第一列,第二列,第三列"
For Each dr As DataRow In DataTables("表A").Select("", cs)
   
    Dim flag As Boolean = False
    If pdr IsNot Nothing Then
        For Each c As String In cs.split(",")
            If pdr(c) <> dr(c) Then
                flag = True
                Exit For
            End If
        Next
    End If
    If flag Then
        If count > 1 Then
            idx &= idx_temp
        End If
        count = 1
        idx_temp = ""
        idx_temp &= dr("_Identify") & ","
    Else
        count += 1
        idx_temp &= dr("_Identify") & ","
    End If
   
    pdr = dr
Next

If count > 1 Then
    idx &= idx_temp
End If

'Tables("表A").filter = "_Identify not in (" & idx.trim(",") & ")"   '显示唯一行

DataTables("表A").DeleteFor("_Identify In (" & idx.trim(",") & ")")  '删除重复行


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106601 积分:542176 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By: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

 回到顶部
帅哥哟,离线,有人找我吗?
天一生水
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1137 积分:11224 威望:0 精华:0 注册:2017/9/26 16:30:00
  发帖心情 Post By:2019/11/15 17:44:00 [只看该作者]

老师好!
我测试还是一样,都删除了。
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:删除重复行.table



 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106601 积分:542176 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/11/15 20:14:00 [只看该作者]

去掉这一句咯

''''''idx_temp &= dr("_Identify") & ","

 回到顶部
帅哥哟,离线,有人找我吗?
天一生水
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1137 积分:11224 威望:0 精华:0 注册:2017/9/26 16:30:00
  发帖心情 Post By:2019/12/1 22:16:00 [只看该作者]

蓝老师好!
如果是临时表,没有_Identify,代码怎么用?


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106601 积分:542176 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/12/1 22:21:00 [只看该作者]

怎么生成的临时表?如果是sql,一样可以添加_Identify。如果没有那就使用其它唯一值的列。如果都没有,请上传实例说明

 回到顶部
帅哥哟,离线,有人找我吗?
天一生水
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1137 积分:11224 威望:0 精华:0 注册:2017/9/26 16:30:00
  发帖心情 Post By:2019/12/1 22:42:00 [只看该作者]

谢谢蓝老师!
我做个实例,删除空行修改以后还是不行,删除重复行也请老师看一下。


图片点击可在新窗口打开查看此主题相关图片如下:截屏图片 (1).jpg
图片点击可在新窗口打开查看

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:测试.rar





 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106601 积分:542176 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By: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

 回到顶部
帅哥哟,离线,有人找我吗?
天一生水
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1137 积分:11224 威望:0 精华:0 注册:2017/9/26 16:30:00
  发帖心情 Post By:2019/12/2 19:36:00 [只看该作者]

老师好!
楼上的代码,如果没有符合条件的,会把最下面一行删除。应该怎样改一下~
谢谢!

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106601 积分:542176 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By: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

 回到顶部
总数 12 1 2 下一页