Хобрук: Ваш путь к мастерству в программировании

Извлечь подстроку из символа A в символ B или EOL, используя Regexp_extract из Big Query/Google Analytics

Я работаю с Google Big Query и пытаюсь извлечь некоторую информацию из строкового столбца в другой столбец, используя Regexp_extract. Короче:

Данные в myVariable:

yippie/eggs-spam/?portlet:hungry=1234
yippie/eggs-spam/?portlet:hungry=456&portlet:hungrier=7890

Я хочу столбец с:

1234
456

Моя команда:

SELECT Regexp_extract(myVariable, r'SOME_MAGIC') as result
FROM table

Я пробовал для SOME_MAGIC:

hungry=(.*)[&$] - null, 456 (I learned that $ is interpreted as is)
hungry=(.*)(&|$) - Error: Exactly one capturing group must be specified
hungry=(.*)^& - null, null
hungry=(&.*)?$ - null, null

Я прочитал это, но там число имеет фиксированную длину . Также просмотрел это, но "?=" неизвестная команда для perl.

У кого-нибудь есть идея? Заранее спасибо!


Ответы:


1

Я только что нашел ответ на то, как я могу решить свою проблему по-другому:

hungry=([0-9]+) - 1234, 456

Это не ответ на мой абстрактный вопрос (регулярное выражение для выбора персонажа A в [Character B или EOL]), так что это не очень удовлетворительно. Например. это не будет работать с

yippie/eggs-spam/?portlet:hungry=12AB34

Однако моя первоначальная проблема решена. Я оставляю вопрос открытым на некоторое время, если у кого-то есть лучший ответ.

11.02.2016

2

Я думаю, что у меня была аналогичная проблема, когда я пытался выбрать последние 6 символов в строке (link_id) в качестве нового столбца.

Я продолжал получать эту ошибку:

Должна быть указана ровно одна группа захвата

Мой код изначально был:

SELECT
...
REGEXP_EXTRACT(link_id, r'......$') AS updated_link_id
FROM sometable;

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

SELECT
...
REGEXP_EXTRACT(link_id, r'(......$)') AS updated_link_id
FROM sometable;
05.11.2016
Новые материалы

Создание кнопочного меню с использованием HTML, CSS и JavaScript
Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

Внедрите OAuth в свои веб-приложения для повышения безопасности
OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

Классы в JavaScript
class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

Как свинг-трейдеры могут использовать ИИ для больших выигрышей
По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

Как построить любой стол
Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

Обзор: Машинное обучение: классификация
Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

Разработка расширений Qlik Sense с qExt
Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..