Поделиться через


Мини-приложения Databricks

Мини-приложения ввода позволяют добавлять параметры в записные книжки и панели мониторинга. Вы можете добавить мини-приложение из пользовательского интерфейса Databricks или с помощью API мини-приложения. Чтобы добавить или изменить мини-приложение, необходимо иметь разрешения CAN EDIT в записной книжке.

Если вы используете Databricks Runtime 11.3 LTS или более поздней версии, вы также можете использовать ipywidgets в записных книжках Databricks.

Мини-приложения Databricks лучше всего подходят для следующих целей:

  • Создание записной книжки или панели мониторинга, которая выполняется повторно с разными параметрами.
  • Быстро просматривайте результаты одного запроса с разными параметрами.

Чтобы просмотреть документацию по API мини-приложений в Scala, Python или R, используйте следующую команду: dbutils.widgets.help() Вы также можете обратиться к документации по служебной программе мини-приложений (dbutils.widgets).

Типы мини-приложений Databricks

Есть четыре типа мини-приложений:

  • text: ввод значения в текстовом поле.
  • dropdown: выберите значение из списка предоставленных значений.
  • combobox: сочетание текста и раскрывающегося списка. Выберите значение из предоставленного списка или входного значения в текстовом поле.
  • multiselect: выберите одно или несколько значений из списка предоставленных значений.

Раскрывающиеся списки мини-приложений и текстовые поля отображаются сразу после панели инструментов записной книжки. Мини-приложения принимают только строковые значения.

Мини-приложение в заголовке

Создание мини-приложений

В этом разделе показано, как создавать мини-приложения с помощью пользовательского интерфейса или программно с помощью магии SQL или API мини-приложений для Python, Scala и R.

Создание мини-приложений с помощью пользовательского интерфейса

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

Выберите Изменить > Добавить виджет. В диалоговом окне "Добавление мини-приложения" введите имя мини-приложения, необязательную метку, тип, тип параметра, возможные значения и необязательное значение по умолчанию. В диалоговом окне имя параметра — это имя, которое вы используете для ссылки на мини-приложение в коде. Метка мини-приложения — это необязательное имя, которое отображается над мини-приложением в пользовательском интерфейсе.

Диалоговое окно создания мини-приложения

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

подсказка мини-приложения

Для редактирования или удаления мини-приложения можно использовать меню кебаб:

меню мини-приложения kebab

Создание мини-приложений с помощью SQL, Python, R и Scala

Программное создание мини-приложений в записной книжке, подключенной к вычислительному кластеру.

API мини-приложения предназначен для согласованности в Scala, Python и R. API мини-приложения в SQL немного отличается, но эквивалентен другим языкам. Вы управляете мини-приложениями с помощью эталонного интерфейса Databricks Utilities (dbutils).

  • Первым аргументом для всех типов мини-приложений является name. Это имя, которое вы используете для доступа к мини-приложению.
  • Второй аргумент — это defaultValueпараметр по умолчанию мини-приложения.
  • Третий аргумент для всех типов мини-приложений (кроме text) — это choices, список значений, которые может взять на себя мини-приложение. Этот аргумент не используется для text мини-приложений типов.
  • Последним аргументом является необязательное значение метки, отображаемой в текстовом поле мини-приложения или раскрывающемся labelсписке.

Python

dbutils.widgets.dropdown("state", "CA", ["CA", "IL", "MI", "NY", "OR", "VA"])

Scala

dbutils.widgets.dropdown("state", "CA", ["CA", "IL", "MI", "NY", "OR", "VA"])

R

dbutils.widgets.dropdown("state", "CA", ["CA", "IL", "MI", "NY", "OR", "VA"])

SQL

CREATE WIDGET DROPDOWN state DEFAULT "CA" CHOICES SELECT * FROM (VALUES ("CA"), ("IL"), ("MI"), ("NY"), ("OR"), ("VA"))

Взаимодействуйте с мини-приложением с помощью панели мини-приложения.

Взаимодействие с мини-приложением

Вы можете получить доступ к текущему значению мини-приложения или получить сопоставление всех мини-приложений:

Python

dbutils.widgets.get("state")

dbutils.widgets.getAll()

Scala

dbutils.widgets.get("state")

dbutils.widgets.getAll()

R

dbutils.widgets.get("state")

SQL

SELECT :state

Наконец, можно удалить мини-приложение или все мини-приложения в записной книжке:

Python

dbutils.widgets.remove("state")

dbutils.widgets.removeAll()

Scala

dbutils.widgets.remove("state")

dbutils.widgets.removeAll()

R

dbutils.widgets.remove("state")

dbutils.widgets.removeAll()

SQL

REMOVE WIDGET state

Если вы удалите мини-приложение, вы не можете создать его в той же ячейке. Мини-приложение необходимо создать в другой ячейке.

Использование значений виджетов в Spark SQL и SQL-хранилище

Виджеты Spark SQL и SQL Warehouse используют значения с помощью маркеров параметров . Маркеры параметров защищают код от атак внедрения SQL, четко разделяя предоставленные значения от инструкций SQL.

Маркеры параметров для мини-приложений доступны в Databricks Runtime 15.2 и выше. Предыдущие версии Databricks Runtime должны использовать старый синтаксис для DBR 15.1 и ниже.

При интерактивном выполнении записных книжек из Spark SQL можно обращаться к мини-приложениям, определенным на любом языке. Рабочий процесс состоит из следующих шагов:

  1. Создайте раскрывающееся приложение всех баз данных в текущем каталоге:

    dbutils.widgets.dropdown("database", "default", [database[0] for database in spark.catalog.listDatabases()])
    
  2. Создайте текстовое мини-приложение, чтобы вручную указать имя таблицы:

    dbutils.widgets.text("table", "")
    
  3. Запустите SQL-запрос, чтобы просмотреть все таблицы в базе данных (выбранные из раскрывающегося списка):

    SHOW TABLES IN IDENTIFIER(:database)
    

    Примечание.

    Необходимо использовать предложение SQL IDENTIFIER() для анализа строк в качестве идентификаторов объектов для баз данных, таблиц, представлений, функций, столбцов и полей.

  4. Вручную введите имя таблицы в мини-приложение table.

  5. Создайте текстовое мини-приложение, чтобы указать значение фильтра:

    dbutils.widgets.text("filter_value", "")
    
  6. Предварительный просмотр содержимого таблицы без необходимости изменять содержимое запроса:

    SELECT *
    FROM IDENTIFIER(:database || '.' || :table)
    WHERE col == :filter_value
    LIMIT 100
    

Использовать значения виджетов в Databricks Runtime версии 15.1 и ниже

В этом разделе описывается, как передавать значения виджетов Databricks в ячейки записной книжки %sql в Databricks Runtime 15.1 и ниже.

  1. Создайте мини-приложения для указания текстовых значений.

Python

 dbutils.widgets.text("database", "")
 dbutils.widgets.text("table", "")
 dbutils.widgets.text("filter_value", "100")

Scala

 dbutils.widgets.text("database", "")
 dbutils.widgets.text("table", "")
 dbutils.widgets.text("filter_value", "100")

R

 dbutils.widgets.text("database", "")
 dbutils.widgets.text("table", "")
 dbutils.widgets.text("filter_value", "100")

SQL

 CREATE WIDGET TEXT database DEFAULT ""
 CREATE WIDGET TEXT table DEFAULT ""
 CREATE WIDGET TEXT filter_value DEFAULT "100"
  1. Передайте значения виджета с помощью синтаксиса ${param}.

    SELECT *
    FROM ${database}.${table}
    WHERE col == ${filter_value}
    LIMIT 100
    

Примечание.

Экранировать символ $ в строковом литерале SQL можно с помощью \$. Например, чтобы выразить строку $1,000, используйте "\$1,000". Символ $ нельзя экранировать для идентификаторов SQL.

Настройка параметров мини-приложения

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

  1. Значок шестеренки Щелкните значок в правом конце панели мини-приложения.

  2. Во всплывающем диалоговом окне параметров на панели мини-приложения выберите поведение выполнения мини-приложения.

    Параметры мини-приложения

    • Run Notebook (Запускать записную книжку). При каждом выборе нового значения вся записная книжка будет перезапускаться.
    • Запуск доступных команд. При каждом выборе нового значения повторно выполняются только ячейки, которые извлекают значения для этого конкретного виджета. Это параметр по умолчанию при создании мини-приложения. В этой конфигурации ячейки SQL не перезапускаются.
    • Действие не требуется. При каждом выборе нового значения перезапуск не выполняется.
  3. Чтобы закрепить мини-приложения в верхней части записной книжки или поместить мини-приложения над первой ячейкой, щелкните Значок закрепления. Параметр сохраняется отдельно для каждого пользователя. Щелкните значок кнопки еще раз, чтобы сбросить настройки по умолчанию.

  4. Если у вас есть разрешение CAN MANAGE для записных книжек, можно настроить макет мини-приложения, щелкнув Значок редактирования. Порядок и размер каждого мини-приложения можно настроить. Чтобы сохранить или закрыть изменения, нажмите кнопку значки accept и cancel.

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

  5. Чтобы сбросить макет мини-приложения в порядок и размер по умолчанию, щелкните значок шестеренки , чтобы открыть диалоговое окно "Параметры панели мини-приложений " и нажмите кнопку Сброс макета. Команда removeAll() не сбрасывает макет виджета.

Мини-приложения Databricks на панелях мониторинга

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

Панель мониторинга с мини-приложениями

Использование мини-приложений Databricks с %run

Если вы запустите записную книжку, содержащую мини-приложения, указанная записная книжка выполняется со значениями по умолчанию для мини-приложений.

Если записная книжка подключена к кластеру (не к хранилищу SQL), можно также передать значения в мини-приложения. Например:

%run /path/to/notebook $X="10" $Y="1"

В этом примере указанная записная книжка запускается и передает 10 в мини-приложение X и 1 в мини-приложение Y.

Ограничения

Дополнительные сведения см. в разделе "Известные ограничения Databricks notebook".