以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- 如何对导入项目内部表的数据,指定某几列的值进行判断,如果不相等,就筛选出来,然后导出使用,如果相等就直接删除。 (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=172610) |
||||
-- 作者:cnsjroom -- 发布时间:2021/10/21 20:08:00 -- 如何对导入项目内部表的数据,指定某几列的值进行判断,如果不相等,就筛选出来,然后导出使用,如果相等就直接删除。 如何对导入项目内部表的数据,指定某几列的值进行判断,如果不相等,就筛选出来,然后导出使用,如果相等就直接删除。 假定表已经有如下数据: 1、想指定第二列 第三列 第四列 或任意列【实际数据列会大于4列】 进行比对,如果不一样就保留,如果一样就不保留,直接删除; 2、没有指定的数据列,暂时不做比对,也不作为数据保留或删除的条件。 3、数据筛选后,将整个表的数据行 按照第一列作为主要条件,分别统计第二列 第三列 第四列或在1中选择的列数进行对应第一列值相同的第二列 第三列 第四列或指定列的数字分列汇总统计。 4、将统计数据进行导出excel或汇总表显示出来。
[此贴子已经被作者于2021/10/21 20:13:51编辑过]
|
||||
-- 作者:有点蓝 -- 发布时间:2021/10/21 20:20:00 -- 参考:http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=83243 |
||||
-- 作者:cnsjroom -- 发布时间:2021/10/21 20:54:00 -- 回复:(有点蓝)参考:http://www.foxtable.com/bbs/... ‘获取表字段列 Dim cnt As Integer = DataTables("表A").DataCols.Count - 1 Dim nms(cnt-1) As String 将nms(i)值在窗体中的组合选择框组件里显示出来 窗口插入一个CheckedListBox控件,一个“确定”按钮,一个“取消”按钮。 Dim
lb As WinForm.CheckedListBox =
e.Form.Controls("CheckedListBox1") “确定”按钮的代码设置为:
Dim s As
String 【老师,上述是先获取指定表中的所有列名称,然后赋值到复选框里,点击确定后,怎么实现所选择的第二列 第三列 第四列进行数据比对呢? 麻烦老师指导下 该楼的所有代码怎么有效融合使用呢?实现选定的指定列,进行数据比对,相同的就筛选为不显示,不相同就显示出来,并且能够导出为excel】 开始比对 Dim idx As String = "-1," If pdr IsNot Nothing Then Tables("表A").filter = "_Identify in (" & idx.trim(",") & ") and 客户 is not null and 工序 is not null" 导出当前表数据为excel Dim dlg As New
SaveFileDialog
\'定义一个新的SaveFileDialog [此贴子已经被作者于2021/10/21 20:55:25编辑过]
|
||||
-- 作者:有点蓝 -- 发布时间:2021/10/21 21:09:00 -- lb.ComboList = string,join("|",nms) …… 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 -- 发布时间:2021/10/21 21:22:00 -- 回复:(有点蓝)lb.ComboList = string,join("|... 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 麻烦老师帮忙看看
|
||||
-- 作者:有点蓝 -- 发布时间: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 -- 发布时间: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(",") & ") " |
||||
-- 作者:有点蓝 -- 发布时间:2021/10/21 22:57:00 -- 原来代码的逻辑是重复的会保留一个,如果想重复的全部不要,看懂代码自行改改 [此贴子已经被作者于2021/10/21 23:34:23编辑过]
|
||||
-- 作者:cnsjroom -- 发布时间:2021/10/22 1:09:00 -- 回复:(有点蓝)原来代码的逻辑是重复的会保留一个,... 老师这个是商业版么 我没有加密狗 直接提示不能打开高版本 楼上代码经过反复学习 代码是实现根据不同的行 如果指定列值相同就只保留一行 怎么也没有成功转换并学习成 多行数据,如果指定的多列 进行列值对比 如果指定的多列值相同 就把符合条件的行数据不显示 只筛选显示出指定的多列 值不相同的行 即同一行多列值比较 不是多行多列值比较 还得麻烦老师继续指导下 不甚感谢!
[此贴子已经被作者于2021/10/22 1:10:34编辑过]
|
||||
-- 作者:有点蓝 -- 发布时间:2021/10/22 8:30:00 -- 下载这里的最新版:http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&Id=171144 |