gpt4 book ai didi

regex - 与正则表达式逻辑作斗争 : how do I remove a param from a url query string?

转载 作者:行者123 更新时间:2023-12-03 15:47:45 24 4
gpt4 key购买 nike

我正在比较 2 个 URL 查询字符串,看看它们是否相等;但是,我想忽略特定的查询参数(始终带有数值)(如果存在)。因此,这两个查询字符串应该相等:

firstName=bobby&lastName=tables&paramToIgnore=2

firstName=bobby&lastName=tables&paramToIgnore=5

因此,我尝试使用 REReplaceNoCase 函数来使用正则表达式替换:

REReplaceNoCase(myQueryString, "&paramToIgnore=[0-9]*", "")

这对于上面的例子来说效果很好。我将替换应用于两个字符串,然后进行比较。问题是我无法确定参数将是字符串中的最后一个...以下 2 个查询字符串也应该相等:

firstName=bobby&lastName=tables&paramToIgnore=2

paramToIgnore=5&firstName=bobby&lastName=tables

因此,我更改了正则表达式,使前面的 & 符号可选... "&?paramToIgnore=[0-9]*"。但是 - 这些字符串仍然不相等,因为我将在其中一个字符串中留下一个额外的&符号,但在另一个字符串中则不然:

firstName=bobby&lastName=tables

&firstName=bobby&lastName=tables

同样,我不能像查询参数一样删除前面的后面的&符号(“&?paramToIgnore = [0-9] *&?”)位于字符串的中间,我将在一个字符串中删除过多的一个&符号,而不是另一个字符串 - 例如

firstName=bobby&lastName=tables&paramToIgnore=2

firstName=bobby&paramToIgnore=5&lastName=tables

将成为

firstName=bobby&lastName=tables

firstName=bobbylastName=tables

我似乎无法理解这个逻辑......任何人都可以帮我找到解决方案吗?

最佳答案

如果您不能确定参数出现的顺序,我建议您不要通过字符串本身来比较它们。

我建议像这样分割字符串:

String stringA = "firstName=bobby&lastName=tables&paramToIgnore=2";
String stringB = "firstName=bobby&lastName=tables&paramToIgnore=5";

String[] partsA = stringA.split("&");
String[] partsB = stringB.split("&");

然后遍历数组并以某种方式使 paramToIgnore 相等:

for(int i = 0; i < partsA.length; i++)
{
if(partsA[i].startsWith("paramToIgnore"){
partsA[i] = "IgnoreMePlease";
}
}

for(int j = 0; j < partsB.length; j++)
{
if(partsB[i].startsWith("paramToIgnore"){
partsB[i] = "IgnoreMePlease";
}
}

然后您可以对数组进行排序和比较,看看它们是否相等:

Arrays.sort(partsA);
Arrays.sort(partsB);
boolean b = Arrays.equals(partsA, partsB);

我非常确定可以使其更加紧凑并提供更好的性能。但是,像您这样比较字符串时,您总是必须关心参数的顺序。

关于regex - 与正则表达式逻辑作斗争 : how do I remove a param from a url query string?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5325594/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com