提取数据时筛掉重复的数据

本文介绍如何使用LayUI和JQuery处理表格数据,包括数据的选择、ID的拼接与传递,以及在控制器中对数据进行分割、转换和查询的方法。详细解释了从用户界面获取数据,到后端处理数据的全过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JQuery:
首先在页面要先获取到你选择的数据,我这里获取到的是layui表格中的某条数据,所以用的是拼接口ID的方式,获取到选中数据的ID,再在控制器通过ID查询出来所需要的数据!拼接完ID之后,用一个post请求把拼接好的字符串ID传到控制器中去。

var checkStatus = layuiTable.checkStatus("tabCommFun");
var filt;
if (checkStatus.data.length > 0) {
var CommId = "";
for (var i = 0; i < checkStatus.data.length; i++) {
CommId += checkStatus.data[i].CommID + ';';
}
CommId = CommId.substring(0, CommId.length - 1);
$("#modAddCommod").modal('hide');
tabTitles.reload({
url: "/OtherWorkManagement/StockAdjustment/SessSelecComm",
where: { CommId: CommId },
});
}
 else {
layer.alert("请先选择商品!", { icon: 0 });
}

控制器:
—在控制器对从页面传递过来的ID字符串进行分割,在页面是以‘;’进行拼接,这里就根据‘;’进行分割,分割完之后就得到了多个单独的ID,将这些单独的ID放入一个字符串数组当中去!
string[] CommIDS = CommId.Split(’;’);
For循环上面的字符串数组,把里面的ID转换为数字的类型,再通过这个ID从数据库中查询出单条数据!

returnJson.State=false
  List<CommoditsVo> listMarket = new List<CommoditsVo>();
for (int i = 0; i < CommIDS.Count(); i++)
{ 
var Commids = Convert.ToInt32(CommIDS[i]);
CommoditsVo dbCommits = (from tbCommits in myModels.B_Commodits
tbCommDeRe.UnitID equals tbUnits.UnitID
                           where tbCommits.CommID == Commids
select new CommoditsVo
{
CommID = tbCommits.CommID,
Catelist = tbCommDeRe.Catelist.Trim(),
FundsNum = tbCommits.FundsNum.Trim(),
Color = tbColor.ColorName.Trim(),           
ToVoNo = tbCommits.ToVoNo,
ToSpecli = tbCommits.ToSpecli,
RegemId = tbCommDeRe.RegimenID,
}).Single();

–遍历上面的空的对象列表,通过里面的数据的ID和刚查询出来的这一条数据进行对比,如果它们的ID相同,声明对象列表中已经存在这一条数据,就把上面声明的一个bool类型的变量变成true,,并且跳出当前循环体(break)!
跳出当前循环体之后判断是否为false,如果为false说明对象列表中没有这一条数据,就把这一条数据添加到对象列表中,如果不为false说明对象中有这一条数据,改变它的状态值,并且查询开启一个新的循环(continue),这样就可以在选择数据时筛掉你所不需要的重复的数据了!

 foreach (var item in listMarket)
{
if (item.CommID == dbCommits.CommID)
{
returnJson.State = true;
break;
}
}
if (returnJson.State==false)
{
listMarket.Add(dbCommits);
}
else
{
returnJson.State = false;
continue;
}
}

把对象列表变成到Session中去,在进行同样的操作时可以减少时间,提高效率!
Session[“listResult”] = listMarket;

### 回答1: 可以使用VBA代码数据表中重复数据。具体做法是:首先使用VBA代码数据表中提取需要选的字段,然后使用VBA代码生成一个临表,将提取来的字段中重复数据剔除,最后将剩余的字段拷贝回原数据表中。 ### 回答2: VBA(Visual Basic for Applications)代码可以用于在Excel中选和去重数据表中的数据。下面是一个简单的示例代码。 首先,打开Excel并进入VBA编辑器。可以通过按下Alt + F11快捷键或单击开发人员选项卡中的“Visual Basic”按钮来访问VBA编辑器。 在VBA编辑器中,选择正确的工作簿和工作表,在该工作表中包含要重的数据。 然后,在视图下拉菜单中选择“工具栏”,确保“控件工具箱”已选中,以便在工具箱中显示所需的控件。 在工具箱中,找到并单击“命令按钮”控件,然后在工作表上单击并拖动,以创建命令按钮。 接下来,右键单击命令按钮,选择“显示代码”以打开按钮的代码窗口。 在代码窗口中,输入以下VBA代码选和去重数据表中的数据: ``` Private Sub CommandButton1_Click() Dim tbl As Range Dim rng As Range Dim cell As Range '设置表格范围(假设数据表从A1开始) Set tbl = Range("A1").CurrentRegion '逐行逐列比较,删除重复值 For Each cell In tbl If WorksheetFunction.CountIf(tbl, cell.Value) > 1 Then cell.ClearContents End If Next cell '删除空行 Set rng = tbl.SpecialCells(xlCellTypeBlanks) rng.Delete Shift:=xlUp End Sub ``` 保存并关闭代码窗口,然后返回Excel工作表。 单击刚才创建的命令按钮,此VBA代码将开始执行。 代码将按行和列遍历数据表,并删除重复的数值。然后,它将删除表格中的空行。 当代码执行完毕后,数据表中将只保留唯一的值,并且不会存在空行。 请注意,该代码假设数据表的起始位置为A1,如果数据表位于不同的位置,需要相应地修改代码中的范围。 这是一个简单的方法来使用VBA代码数据表进行选和去重,根据实际需求,可能需要进一步修改和调整代码。 ### 回答3: 使用VBA代码可以很方便地将数据表中的数据进行重。 首先,我们需要定义一个变量来表示当前工作表,可以使用以下代码行来实现: Dim ws As Worksheet Set ws = ThisWorkbook.Sheets("Sheet1") 接下来,我们可以通过创建一个集合对象来存储重后的数据。集合对象可以确保每个元素的值都是唯一的,这样就能将重复数据自动排除。 Dim uniqueData As Collection Set uniqueData = New Collection 然后,我们可以使用循环语句遍历数据表中的数据,并将每个值添加到集合中。如果集合中已经存在相同的值,就会自动忽略。 Dim lastRow As Long lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row Dim i As Long For i = 2 To lastRow On Error Resume Next uniqueData.Add Item:=ws.Cells(i, 1).Value, Key:=CStr(ws.Cells(i, 1).Value) On Error GoTo 0 Next i 最后,我们可以将重后的数据放入一个新的工作表中,从第一行开始逐行写入。 Dim newWs As Worksheet Set newWs = ThisWorkbook.Sheets.Add Dim j As Long For j = 1 To uniqueData.Count newWs.Cells(j, 1).Value = uniqueData(j) Next j 这样,我们就可以通过使用以上的VBA代码数据表中的数据进行重,最终得到一个只包含独立值的新工作表。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值