js脚本去除mongo里某个数组字段的特殊字符

本文知识要点
  • set去重
  • set转数组,数组转为set
  • js的正则验证

set去重,将一个数组转为set集合

var arrSyn=[];
var synResult = new Set(arrSyn);

使用正则表达式验证字符串内容

//.test(arrSyn[item])

将set集合转为数组

var arr = Array.from(synResult)

全部代码是这样子的:

var find = db.getCollection("mycollection").find({ "搜索条件" });
find.forEach(function(event) {
	var arrSyn = event.arr;
	var synResult = new Set(arrSyn); //将数组转为set集合去重
	var flag = false;
	for(var item in arrSyn) {
		//正则验证有无相应的特殊字符
		if(//.test(arrSyn[item])) {
			synResult.add(arrSyn[item].replace(//, ""));
			flag = true;
		}
	}
	if(flag) {
		var arr = Array.from(synResult);//set集合转为数组
		print(arr.length +" "+ event.synonyms.length);
		print( event._id);
		db.getCollection("").update(
			{"_id":event._id}, {$set:{"arr":Array.from(synResult)}}
		);
	}
})

水平原因,如果存在错误,请联系我 chenrui@marsdl.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值