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


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

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

帅哥哟,离线,有人找我吗?
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编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | 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编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | 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



 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | 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(",") & ") "



 回到顶部
帅哥哟,离线,有人找我吗?
cnsjroom
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | 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编辑过]

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


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)下载这里的最新版:http://www.foxta...  发帖心情 Post By:2021/10/22 12:14:00 [显示全部帖子]

谢谢老师   已经下载新版   运行之后还是没有得到预期效果  麻烦老师继续指导下  谢谢! 
原始数据

图片点击可在新窗口打开查看此主题相关图片如下:捕获1.png
图片点击可在新窗口打开查看
选择第二列 第三列之后运行得到的数据

图片点击可在新窗口打开查看此主题相关图片如下:捕获2.png
图片点击可在新窗口打开查看
筛选后的数据还存在第二列 第三列值一样的数据   想实现的效果是筛选后  假定被选择的第二列 第三列值相同的话  该行数据不显示   反之就显示出来

选择第二列第三列第四列得到错误提示
.NET Framework 版本:4.0.30319.42000
Foxtable 版本:2021.9.2.1
错误所在事件:
详细错误信息:
语法错误: IN 关键字后面必须是由逗号分隔的非空表达式列表,并且必须用括号括起来。
筛选后的数据为空白
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:测试.table



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


加好友 发短信
等级:七尾狐 帖子:1571 积分:11238 威望:0 精华:0 注册:2021/1/17 17:06:00
回复:(有点蓝)嗯!我们理解的不是一个东西。我以为...  发帖心情 Post By:2021/10/25 16:07:00 [显示全部帖子]

有点蓝老师
现在同一个数据行之间的问题OK了
不同数据行之间 现在运行貌似  如果没有相同的数据  就会提示如图错误  【麻烦老师继续指导下  谢谢!】

图片点击可在新窗口打开查看此主题相关图片如下:1.png
图片点击可在新窗口打开查看
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:测试.table

  当前不同行数据的确定筛选代码如下:
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

Dim idx As String = ""

Dim lst As new List(of String)
Dim flag As Boolean

Dim drs As List(Of  DataRow) = DataTables("表A").Select("第一列 is not null", cs)
Dim pdr As DataRow = drs(0)
Dim dr As DataRow
For i As Integer = 1 To drs.count - 1
    dr = drs(i)
    flag = False
    For Each c As String In cs.split(",")
        If pdr(c) <> dr(c) Then
            flag = True
            Exit For
        End If
    Next
    If flag = False Then
        If lst.Contains(pdr("_Identify")) = False
            lst.add( pdr("_Identify") )
        End If
        lst.add( dr("_Identify") )
    End If
    pdr = dr
Next

If lst.count > 0 Then
    idx = String.Join(",",lst.ToArray)
End If

Tables("表A").filter = "第一列 is not null and _Identify not in (" & idx.trim(",") & ") "

 回到顶部