使用正则表达式时,如何确保/处理重复值?
在我的场景中,我需要从我的回复中捕获多个优惠。但是不能在交易中一次又一次地使用相同的报价
答案 0 :(得分:0)
有多种方法可以做到这一点。如果您使用默认的Regular Expression Extractor
,问题是它会创建变量(例如:offer_1,offer_2等),随时可以执行。如果它返回某种ArrayList
我们可以删除重复项,那会更容易。我要建议的是将这些变量添加到JSR223(groovy) sampler/post processor的列表中,然后将它们转换回通常的jmeter变量,以便在通常的jmeter脚本流程中使用。
<强>段:强>
我根据您的描述创建了一个示例脚本,该脚本将返回多个商品并带有一些副本。以下是后处理之前的jmeter变量的状态。
offer_1=RUSSIA
offer_1_g=1
offer_1_g0=offer="RUSSIA"
offer_1_g1=RUSSIA
offer_2=UK
offer_2_g=1
offer_2_g0=offer="UK"
offer_2_g1=UK
offer_3=ICELAND
offer_3_g=1
offer_3_g0=offer="ICELAND"
offer_3_g1=ICELAND
offer_4=USA
offer_4_g=1
offer_4_g0=offer="USA"
offer_4_g1=USA
offer_5=UK
offer_5_g=1
offer_5_g0=offer="UK"
offer_5_g1=UK
offer_6=USA
offer_6_g=1
offer_6_g0=offer="USA"
offer_6_g1=USA
offer_7=USA
offer_7_g=1
offer_7_g0=offer="USA"
offer_7_g1=USA
offer_matchNr=7
正如您在上面所看到的,变量中存在重复项。将以下Groovy代码放在JSR223后处理器中,并选择groovy作为语言。
// Count of offers extracted by Regular Expression Extractor
def count = Integer.parseInt(vars.get("offer_matchNr"))
// An empty list which will store the offers
def offer_list = []
for (int i = 1; i <= count; i++){
def offer = vars.get("offer_" + i)
offer_list.add(offer)
}
// Removes the duplicates in the list
offer_list.unique()
// Following one liner adds new variables but with only unique offers in similar format as jmeter variable.
offer_list.eachWithIndex{ it, index -> vars.put("unique_offer_${index+1}", "${it}")}
后期处理:
unique_offer_1=RUSSIA
unique_offer_2=UK
unique_offer_3=ICELAND
unique_offer_4=USA