Нужно найти регулярное выражение для выборки только тех полей, которые я хочу - PullRequest
0 голосов
/ 24 июня 2019

Я ищу регулярное выражение, чтобы разбить отслеживаемое событие, а затем разделить каждый из этих фрагментов кода. Есть идеи, как мне этого добиться?

Я собираю это в GA и хотел бы разбить это в Data Studio. Я хотел бы использовать выражение Регула, чтобы получить только те части, которые мне нужны.

Я бы хотел отфильтровать по событию:

event category = Enrollment
event action =  UtilitySelected
and then fetch only the parts I need form the event label 

Вот что мне нужно помешать в метке события:

ip=73.155.208.187|clientid=1907637160.1561128460|zip=77024|promo=|utmcsr=(direct)|utmcmd=(none)|utmccn=(not set)|landingpage=https://www.constellation.com/content/constellation/en/solutions/for-your-home/residential-signup.html?zip=77024&promoCode=|plan=Electric|rate=10.3¢ |term=12 Month Term(CNP)|email=kmagon@capitalbuildershouston.com|res-type=house|address=247 HEDWIG RD HOUSTON, TX 770246735|visits=https://www.constellation.com/content/constellation/en/solutions/for-your-home/residential-signup.html?zip=77024&promoCode=

В идеале мне нужно было бы регулярное выражение, которое говорило бы, что я только получаю Enrollment & UtilitySelected, и только показываю рейтинг и скрываю все, что за ним.

rate=10.3¢ 

Проблема в том, что я не знаю, как выполнить детализацию на основе этих двух элементов и скрыть данные после нужного мне поля.

Не знаю, правильно ли я объясняю это. Пожалуйста, не стесняйтесь задавать вопросы.

Ответы [ 2 ]

2 голосов
/ 24 июня 2019

Один из вариантов - использовать комбинацию split , filter и начинается с :

str.split("|").filter(x => x.startsWith("rate="))[0].trim();

Разделить на трубу |, отфильтровать массив, где строка начинается с rate=, и получить первое значение. Затем используйте аккуратный, чтобы удалить пробелы.

let str = `ip=73.155.208.187|clientid=1907637160.1561128460|zip=77024|promo=|utmcsr=(direct)|utmcmd=(none)|utmccn=(not set)|landingpage=https://www.constellation.com/content/constellation/en/solutions/for-your-home/residential-signup.html?zip=77024&promoCode=|plan=Electric|rate=10.3¢ |term=12 Month Term(CNP)|email=kmagon@capitalbuildershouston.com|res-type=house|address=247 HEDWIG RD HOUSTON, TX 770246735|visits=https://www.constellation.com/content/constellation/en/solutions/for-your-home/residential-signup.html?zip=77024&promoCode=`;

str = str.split("|").filter(x => x.startsWith("rate="))[0].trim();
console.log(str);
0 голосов
/ 24 июня 2019

Здесь мы, вероятно, можем разработать простое выражение, которое извлекло бы эти желаемые значения, например:

category\s*=\s*([^\s]+)|action\s*=\s*([^\s]+)

Пожалуйста, ознакомьтесь с демонстрацией для дополнительного объяснения.

Для извлечения ставки, я не совсем уверен, что может быть желательным, мы можем начать с этого выражения:

(?=.*plan=.*|)(rate=[^\s]+)(?=.*)

и установить наши границы для него.

Дополнительную информацию см. В демоверсии.

ТЕСТ

const regex = /(?=.*plan=.*|)(rate=[^\s]+)(?=.*)/gm;
const str = `ip=73.155.208.187|clientid=1907637160.1561128460|zip=77024|promo=|utmcsr=(direct)|utmcmd=(none)|utmccn=(not set)|landingpage=https://www.constellation.com/content/constellation/en/solutions/for-your-home/residential-signup.html?zip=77024&promoCode=|plan=Electric|rate=10.3¢ |term=12 Month Term(CNP)|email=kmagon@capitalbuildershouston.com|res-type=house|address=247 HEDWIG RD HOUSTON, TX 770246735|visits=https://www.constellation.com/content/constellation/en/solutions/for-your-home/residential-signup.html?zip=77024&promoCode=
`;
let m;

while ((m = regex.exec(str)) !== null) {
    // This is necessary to avoid infinite loops with zero-width matches
    if (m.index === regex.lastIndex) {
        regex.lastIndex++;
    }
    
    // The result can be accessed through the `m`-variable.
    m.forEach((match, groupIndex) => {
        console.log(`Found match, group ${groupIndex}: ${match}`);
    });
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...