以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- [讨论]关于并列名次 (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=143080) |
-- 作者:工匠 -- 发布时间:2019/11/13 10:44:00 -- [讨论]关于并列名次 老师好: 关于并列名次,请教如何实现(参考其它例子,但是结果效果却不一样) Dim pcs As List(Of String) = DataTables("进出分析").GetValues("计算") For Each pc As String In pcs Dim drs As List(Of DataRow) = DataTables("进出分析").Select("[计算] = \'" & pc & "\'", "批次 DESC") For n As Integer = 0 To drs.Count - 1 \'遍历所有行 If n > 0 AndAlso drs(n)("批次") = drs(n-1)("批次") Then \'如果批次和上一行相同 drs(n)("批次排名") = drs(n-1)("批次排名") \'则批次排名等于上一行 Else drs(n)("批次排名") = n + 1 \'设置批次排名 End If Next Next Dim pcs1 As List(Of String) = DataTables("进出分析").GetValues("计算") For Each pc1 As String In pcs1 Dim drs1 As List(Of DataRow) = DataTables("进出分析").Select("[计算] = \'" & pc1 & "\'", "采购数量 DESC") For n1 As Integer = 0 To drs1.Count - 1 \'遍历所有行 If n1 > 0 AndAlso drs1(n1)("数量排名") = drs1(n1-1)("数量排名") Then \'如果名次和上一行相同 drs1(n1)("数量排名") = drs1(n1-1)("数量排名") \'则名次排名等于上一行 Else drs1(n1)("数量排名") = n1 + 1 \'设置批次排名 End If Next Next 计算显示错误效果 谢谢! 已参考:http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&replyID=475518&ID=69207&skin=1 [此贴子已经被作者于2019/11/13 10:56:45编辑过]
|
-- 作者:有点蓝 -- 发布时间:2019/11/13 10:55:00 -- Dim pcs As List(Of String) = DataTables("进出分析").GetValues("计算") For Each pc As String In pcs Dim drs As List(Of DataRow) = DataTables("进出分析").Select("[计算] = \'" & pc & "\'", "批次 DESC") For n As Integer = 0 To drs.Count - 1 \'遍历所有行 drs(n)("批次排名") = n + 1 Next Dim drs1 As List(Of DataRow) = DataTables("进出分析").Select("[计算] = \'" & pc1 & "\'", "采购数量 DESC") For n1 As Integer = 0 To drs1.Count - 1 \'遍历所有行 If n1 > 0 AndAlso drs1(n1)("采购数量") = drs1(n1-1)("采购数量") Then \'如果名次和上一行相同 drs1(n1)("数量排名") = drs1(n1-1)("数量排名") \'则名次排名等于上一行 Else drs1(n1)("数量排名") = n1 + 1 \'设置批次排名 End If Next Next |
-- 作者:工匠 -- 发布时间:2019/11/13 11:21:00 -- 谢谢老师,还是不行,是不是我的系统平台和人家系统平台不一样呢,无论是计算单项排名还是多项排名,都是乱的,代码只有列名不同而已............ 现上传例子,请帮看看,是不是我系统平台异常?
|
-- 作者:有点蓝 -- 发布时间:2019/11/13 11:35:00 -- 测试没有问题,有什么问题?截图说明 |
-- 作者:有点蓝 -- 发布时间:2019/11/13 11:38:00 -- 这个意思? Dim pcs As List(Of String) = DataTables("进出分析").GetValues("计算") For Each pc As String In pcs Dim drs As List(Of DataRow) = DataTables("进出分析").Select("[计算] = \'" & pc & "\'", "批次 DESC,[_Identify]") Dim idx As Integer = 1 For n As Integer = 0 To drs.Count - 1 \'遍历所有行 If n > 0 AndAlso drs(n)("批次") = drs(n-1)("批次") Then \'如果批次和上一行相同 drs(n)("批次排名") = drs(n-1)("批次排名") \'则批次排名等于上一行 Else drs(n)("批次排名") = idx \'设置批次排名 idx += 1 End If Next idx = 1 Dim drs1 As List(Of DataRow) = DataTables("进出分析").Select("[计算] = \'" & pc & "\'", "采购数量 DESC") For n1 As Integer = 0 To drs1.Count - 1 \'遍历所有行 If n1 > 0 AndAlso drs1(n1)("采购数量") = drs1(n1-1)("采购数量") Then \'如果名次和上一行相同 drs1(n1)("数量排名") = drs1(n1-1)("数量排名") \'则名次排名等于上一行 Else drs1(n1)("数量排名") = idx \'设置批次排名 idx += 1 End If Next Next |
-- 作者:工匠 -- 发布时间:2019/11/14 9:48:00 -- 谢谢老师,就是这种效果,这种方法得出的数据用于目标激励和物料备库计划有很大的参考作用 |