设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 1127|回复: 3
打印 上一主题 下一主题

[窗体] [求助]如何一次排除列表框的值

[复制链接]
跳转到指定楼层
1#
发表于 2008-12-14 09:42:09 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

如图,按了"组合"和"增加"按钮后,再按"过滤"按钮,不过不是一次将组合结果的值排除出来,要通过几次按"过滤"按钮才可以将所有值排除出来
我的"过滤"按钮代码如下:
Private Sub cmdGL_Click()
Dim numPC, numZH As Long
'lstPC:排除列表
'lstGJZH:组合结果列表
For numPC = 0 To Me.lstPC.ListCount - 1
    For numZH = 0 To Me.lstGJZH.ListCount - 1
        If InStr(1, Me.lstGJZH.ItemData(numZH), Me.lstPC.ItemData(numPC)) > 0 Then
            'Debug.Print "排除第:" & numPC + 1
            'Debug.Print Me.lstPC.ItemData(numPC)
            'Debug.Print "组合第:" & numZH + 1
            'Debug.Print Me.lstGJZH.ItemData(numZH)
            'Debug.Print "位置在:" & InStr(1, Me.lstGJZH.ItemData(numZH), Me.lstPC.ItemData(numPC))
            'Debug.Print "--------"
            Me.lstGJZH.RemoveItem numZH
        End If
    Next numZH
Next numPC
Call StBarXS
End Sub
源文件:


[ 本帖最后由 ikon 于 2008-12-14 09:45 编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 分享淘帖 订阅订阅
4#
 楼主| 发表于 2008-12-29 11:49:54 | 只看该作者
经过几经研究,自己解决了,谢谢提示
Private Sub cmdGL_Click()
Dim numPC, numZH  As Long

For numPC = 0 To Me.lstPC.ListCount - 1
    For numZH = 0 To Me.lstGJZH.ListCount
        If InStr(1, Me.lstGJZH.ItemData(numZH), Me.lstPC.ItemData(numPC)) > 0 Then
            Me.lstGJZH.RemoveItem numZH
            numZH = numZH - 1
        End If
    Next
Next

StBarXS
3#
发表于 2008-12-14 09:53:20 | 只看该作者
2#
 楼主| 发表于 2008-12-14 09:49:36 | 只看该作者
本人通过监视
"Me.lstGJZH.ItemData(numZH)"和"InStr(1, Me.lstGJZH.ItemData(numZH), Me.lstPC.ItemData(numPC))"的值,
发现按完一次"过滤"按钮后,"Me.lstGJZH.ItemData(numZH)"和"InStr(1, Me.lstGJZH.ItemData(numZH), Me.lstPC.ItemData(numPC))"的值的值都是null

而"Me.lstPC.ItemData(numPC)) "的值很正常

[ 本帖最后由 ikon 于 2008-12-14 09:50 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2025-1-25 10:57 , Processed in 0.106274 second(s), 29 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表