Foxtable(狐表)用户栏目专家坐堂 → [求助]筛选时怎么排除隐藏行


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

主题:[求助]筛选时怎么排除隐藏行

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


加好友 发短信
等级:幼狐 帖子:174 积分:1671 威望:0 精华:0 注册:2018/4/22 18:54:00
[求助]筛选时怎么排除隐藏行  发帖心情 Post By:2018/10/13 15:39:00 [只看该作者]

各位老师,在主窗口中有一个筛选面板,主窗口的表名是《人员信息表》,《人员信息表》中有隐藏的行,即在职人员显示、离职人员隐藏,现在我想对可见行按条件进行筛选。我参照帮助文件写的筛选代码是:

Dim Filter As String

With e.Form.Controls("县市区")
    If .Value IsNot Nothing Then
        Filter = "县市区 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("乡镇办")
    If .Value IsNot Nothing Then
        Filter = "乡镇办 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("现任职务")
    If .Value IsNot Nothing Then
        Filter = "现任职务 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("文化程度")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "文化程度 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("政治面貌")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "政治面貌 = '" & .Value & "'"
    End If
End With

If Filter > "" Then
    Tables("人员信息表").Filter = Filter
End If

问题是在点击筛选按钮进行筛选后,隐藏的行也会显示出来。但我只希望筛选可见行,请问怎么写筛选代码?谢谢!
补充说明一下,我用的隐藏代码是:Tables("人员信息表").Filter = "任职状态 <> '离职'"    '-----隐藏离职的行
[此贴子已经被作者于2018/10/13 15:40:09编辑过]

 回到顶部
帅哥,在线噢!
y2287958
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:狐神 帖子:4772 积分:34668 威望:0 精华:0 注册:2008/8/31 22:44:00
  发帖心情 Post By:2018/10/13 15:42:00 [只看该作者]

加上原来的条件就可以了

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


加好友 发短信
等级:幼狐 帖子:174 积分:1671 威望:0 精华:0 注册:2018/4/22 18:54:00
  发帖心情 Post By:2018/10/13 15:45:00 [只看该作者]

谢谢y2287958马上给出解答,可是代码我不会写,能麻烦您写一下吗?

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


加好友 发短信
等级:幼狐 帖子:174 积分:1671 威望:0 精华:0 注册:2018/4/22 18:54:00
  发帖心情 Post By:2018/10/13 15:47:00 [只看该作者]

下面的写法是把隐藏代码加到筛选代码后面,我已经试过了,筛选动作就无法执行了,点击筛选按钮没的反应

Dim Filter As String

With e.Form.Controls("县市区")
    If .Value IsNot Nothing Then
        Filter = "县市区 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("乡镇办")
    If .Value IsNot Nothing Then
        Filter = "乡镇办 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("现任职务")
    If .Value IsNot Nothing Then
        Filter = "现任职务 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("文化程度")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "文化程度 = '" & .Value & "'"
    End If
End With

With e.Form.Controls("政治面貌")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "政治面貌 = '" & .Value & "'"
    End If
End With

If Filter > "" Then
    Tables("人员信息表").Filter = Filter
End If

Tables("人员信息表").Filter = "任职状态 <> '离职'"    '-----隐藏离职的行


 回到顶部
帅哥,在线噢!
有点蓝
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111389 积分:567009 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2018/10/13 15:52:00 [只看该作者]

If Filter > "" Then
    Tables("人员信息表").Filter = Filter & " and 任职状态 <> '离职'"
End If

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


加好友 发短信
等级:幼狐 帖子:174 积分:1671 威望:0 精华:0 注册:2018/4/22 18:54:00
  发帖心情 Post By:2018/10/13 15:58:00 [只看该作者]

有点蓝老师太牛了,轻而易举帮我解决了问题,谢谢

 回到顶部