Foxtable(狐表)用户栏目专家坐堂 → 如何对导入项目内部表的数据,指定某几列的值进行判断,如果不相等,就筛选出来,然后导出使用,如果相等就直接删除。


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

主题:如何对导入项目内部表的数据,指定某几列的值进行判断,如果不相等,就筛选出来,然后导出使用,如果相等就直接删除。

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


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
如何对导入项目内部表的数据,指定某几列的值进行判断,如果不相等,就筛选出来,然后导出使用,如果相等就直接删除。  发帖心情 Post By:2021/10/21 20:08:00 [只看该作者]

如何对导入项目内部表的数据,指定某几列的值进行判断,如果不相等,就筛选出来,然后导出使用,如果相等就直接删除。
假定表已经有如下数据:
1、想指定第二列  第三列  第四列 或任意列【实际数据列会大于4列】 进行比对,如果不一样就保留,如果一样就不保留,直接删除;
2、没有指定的数据列,暂时不做比对,也不作为数据保留或删除的条件。
3、数据筛选后,将整个表的数据行  按照第一列作为主要条件,分别统计第二列  第三列   第四列或在1中选择的列数进行对应第一列值相同的第二列  第三列 第四列或指定列的数字分列汇总统计。
4、将统计数据进行导出excel或汇总表显示出来。

图片点击可在新窗口打开查看此主题相关图片如下:1.png
图片点击可在新窗口打开查看
也就是假设我指定了第二三四列  那么三列都相同就删除   橡皮檫  三角尺  数据行直接删除  因为第二 第三 第四列均为一样
如果我指定了第二三列  那么两列相同就删除  如钢笔数据行
[此贴子已经被作者于2021/10/21 20:13:51编辑过]

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


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

参考:http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=83243

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


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)参考:http://www.foxtable.com/bbs/...  发帖心情 Post By:2021/10/21 20:54:00 [只看该作者]

‘获取表字段列

Dim cnt As Integer = DataTables("表A").DataCols.Count - 1

Dim nms(cnt-1) As String
For i As Integer = 0 To cnt - 1
    nms(i) = DataTables("表A").DataCols(i).name
Next


将nms(i)值在窗体中的组合选择框组件里显示出来


窗口插入一个CheckedListBox控件,一个“确定”按钮,一个“取消”按钮。
窗口的AfterLoad事件代码设置为:

Dim lb As WinForm.CheckedListBox = e.Form.Controls("CheckedListBox1")
lb
.ComboListnms(i) 


“确定”按钮的代码设置为:

Dim s As String
Dim
l As WinForm
.CheckedListBox = e.Form.Controls("CheckedListBox1")
For
Each Index As Integer In l
.CheckedIndices
    If
s > "" Then
        s = s &
","
   
End If
    s = s &
"'" & l
.
Items(Index) & "'"
Next
If
s > "" Then
    Tables
("订单").Filter = "产品 In (" & s & ")"
End
If

e
.Form.Close()



【老师,上述是先获取指定表中的所有列名称,然后赋值到复选框里,点击确定后,怎么实现所选择的第二列 第三列  第四列进行数据比对呢?

麻烦老师指导下   该楼的所有代码怎么有效融合使用呢?实现选定的指定列,进行数据比对,相同的就筛选为不显示,不相同就显示出来,并且能够导出为excel】


开始比对

Dim idx As String = "-1,"
Dim pdr As DataRow = Nothing
Dim cs As String = "客户,工序"    如何换成上述的S值
Dim flag As Boolean
For Each dr As DataRow In DataTables("表A").Select("客户 is not null and 工序 is not null", cs)
    flag = 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
        idx &= pdr("_Identify") & ","
    End If
    pdr = dr
Next

If pdr IsNot Nothing Then
    idx &= pdr("_Identify") & ","
End If

Tables("表A").filter = "_Identify in (" & idx.trim(",") & ") and 客户 is not null and 工序 is not null"



导出当前表数据为excel

Dim dlg As New SaveFileDialog '定义一个新的SaveFileDialog
dlg.Filter=
"excel文件|*.xls" '设置筛选器
If
dlg.ShowDialog = DialogResult.Ok Then '如果用户单击了确定按钮
    Dim
ex As New Exporter
   
ex.SourceTableName = "表A" '指定导出
   
ex.filepath = dlg.FileName  '指定目标文件
   
ex.Export() '开始导出
End If

[此贴子已经被作者于2021/10/21 20:55:25编辑过]

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


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

lb.ComboList = string,join("|",nms)
……

Dim
 s As String
Dim
 l As WinForm
.CheckedListBox = e.Form.Controls("CheckedListBox1")
For
 Each Index As Integer In l
.CheckedIndices
    s = s & 
"," & l
.
Items(Index)
Next
s = s.trim(",")
Dim cs As String =  s

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


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)lb.ComboList = string,join("|...  发帖心情 Post By:2021/10/21 21:22:00 [只看该作者]

Dim cnt As Integer = DataTables("表A").DataCols.Count - 1
Dim nms(cnt-1) As String
Dim lb As WinForm.CheckedListBox = e.Form.Controls("CheckedListBox1")
For i As Integer = 0 To cnt - 1
    nms(i) = DataTables("表A").DataCols(i).name
    output.show(nms(i))
    'lb.ComboList = String,join("|",nms)
Next


图片点击可在新窗口打开查看此主题相关图片如下:捕获.png
图片点击可在新窗口打开查看

麻烦老师帮忙看看
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目1.table



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


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

建议多看看编程基础了,连基本的语法都还不行

Dim cnt As Integer = DataTables("表A").DataCols.Count - 1
Dim nms(cnt-1) As String
Dim lb As WinForm.CheckedListBox = e.Form.Controls("CheckedListBox1")
For i As Integer = 0 To cnt - 1
    nms(i) = DataTables("表A").DataCols(i).name
    output.show(nms(i))
Next
lb.ComboList = String.join("|",nms)

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


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)建议多看看编程基础了,连基本的语法...  发帖心情 Post By:2021/10/21 22:49:00 [只看该作者]

再麻烦老师帮忙指导下  谢谢!
程序运行后没有实现一楼的效果   
选择了第二列 第三列  没有将两个相同内容的行隐藏  只保留不相同的数据行筛选显示出来

确定按钮代码
Dim s As String
Dim l As WinForm.CheckedListBox = e.Form.Controls("CheckedListBox1")
For Each Index As Integer In l.CheckedIndices
    s = s & "," & l.Items(Index)
Next
s = s.trim(",")
Dim cs As String =  s

MessageBox.Show(cs)   可以弹出选择的“第二列,第三列”
Dim idx As String = "-1,"
Dim pdr As DataRow = Nothing

Dim flag As Boolean
For Each dr As DataRow In DataTables("表A").Select("", cs)
    flag = False
    
    If pdr IsNot Nothing Then
        For Each c As String In cs.split(",")
            MessageBox.Show(pdr(c))  ’会弹出空值
            MessageBox.Show(dr(c))
            If pdr(c) <> dr(c) Then
                flag = True
                Exit For
            End If
        Next
    End If
    If flag Then
        idx &= pdr("_Identify") & ","
    End If
    pdr = dr
Next

If pdr IsNot Nothing Then
    idx &= pdr("_Identify") & ","
End If

Tables("表A").filter = "_Identify in (" & idx.trim(",") & ") "



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


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

原来代码的逻辑是重复的会保留一个,如果想重复的全部不要,看懂代码自行改改

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目1 (6).zip


[此贴子已经被作者于2021/10/21 23:34:23编辑过]

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


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)原来代码的逻辑是重复的会保留一个,...  发帖心情 Post By:2021/10/22 1:09:00 [只看该作者]

老师这个是商业版么  我没有加密狗 直接提示不能打开高版本

楼上代码经过反复学习  
代码是实现根据不同的行 如果指定列值相同就只保留一行

怎么也没有成功转换并学习成
多行数据,如果指定的多列 进行列值对比   如果指定的多列值相同  就把符合条件的行数据不显示  只筛选显示出指定的多列  值不相同的行
即同一行多列值比较  不是多行多列值比较
还得麻烦老师继续指导下   不甚感谢!
[此贴子已经被作者于2021/10/22 1:10:34编辑过]

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


加好友 发短信
等级:超级版主 帖子:107523 积分:546900 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/10/22 8:30:00 [只看该作者]

下载这里的最新版:http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&Id=171144

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