Class DataViewDefinitionBuilder

DataViewDefinitionBuilder

Конструктор для объектов DataViewDefinition .

Вот пример использования конструктора. Данные импортируются из электронной таблицы Google .

function doGet() {
  // This example creates two table charts side by side. One uses a data view
  // definition to restrict the number of displayed columns.

  // Get sample data from a spreadsheet.
  const dataSourceUrl = 'https://docs.google.com/spreadsheet/tq?range=A1%3AF' +
      '&key=0Aq4s9w_HxMs7dHpfX05JdmVSb1FpT21sbXd4NVE3UEE&gid=4&headers=-1';

  // Create a chart to display all of the data.
  const originalChart = Charts.newTableChart()
                            .setDimensions(600, 500)
                            .setDataSourceUrl(dataSourceUrl)
                            .build();

  // Create another chart to display a subset of the data (only columns 1 and
  // 4).
  const dataViewDefinition = Charts.newDataViewDefinition().setColumns([0, 3]);
  const limitedChart = Charts.newTableChart()
                           .setDimensions(200, 500)
                           .setDataSourceUrl(dataSourceUrl)
                           .setDataViewDefinition(dataViewDefinition)
                           .build();

  const htmlOutput = HtmlService.createHtmlOutput();
  const originalChartData = Utilities.base64Encode(
      originalChart.getAs('image/png').getBytes(),
  );
  const originalChartUrl =
      `data:image/png;base64,${encodeURI(originalChartData)}`;
  const limitedChartData = Utilities.base64Encode(
      limitedChart.getAs('image/png').getBytes(),
  );
  const limitedChartUrl =
      `data:image/png;base64,${encodeURI(limitedChartData)}`;
  htmlOutput.append('<table><tr><td>');
  htmlOutput.append(`<img border="1" src="${originalChartUrl}">`);
  htmlOutput.append('</td><td>');
  htmlOutput.append(`<img border="1" src="${limitedChartUrl}">`);
  htmlOutput.append('</td></tr></table>');
  return htmlOutput;
}

Методы

Метод Тип возвращаемого значения Краткое описание
build() Data View Definition Создает и возвращает объект определения представления данных, который был создан с помощью этого построителя.
set Columns(columns) Data View Definition Builder Задает индексы столбцов, которые следует включить в представление данных, а также указывает информацию о роли столбцов.

Подробная документация

build()

Создает и возвращает объект определения представления данных, который был создан с помощью этого построителя.

Возвращаться

DataViewDefinition — объект определения представления данных, созданный с помощью этого построителя.


setColumns(columns)

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

Роль столбца описывает назначение данных в этом столбце: например, столбец может содержать данные, описывающие текст всплывающих подсказок, аннотации точек данных или индикаторы неопределенности. Более подробную информацию см. в разделе «Роли DataTable» в документации Google Charts.

Предположим, что в ячейках A1:C3 находится электронная таблица со следующими данными:

'abc', 20, 'blue';
'def', 30, 'red';
'ghi', 40, 'orange';
Приведенный ниже код создает столбчатую диаграмму, где каждый столбец имеет свой цвет. Цвета назначаются с помощью стиля "роль столбца".
const COLUMN_SPEC = [
  0,  // categories
  1,  // counts
  {sourceColumn: 2, role: 'style'},
];

function roleColumnChart() {
  const spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
  const sheet = spreadsheet.getActiveSheet();
  const viewSpec =
      Charts.newDataViewDefinition().setColumns(COLUMN_SPEC).build();
  const chartBuilder = sheet.newChart()
                           .setChartType(Charts.ChartType.BAR)
                           .setDataViewDefinition(viewSpec)
                           .setOption('useFirstColumnAsDomain', true)
                           .setPosition(5, 1, 0, 0)
                           .setOption('hAxis', {title: 'Counts'})
                           .setOption('vAxis', {title: 'Categories'})
                           .addRange(sheet.getRange('A1:C3'));
  sheet.insertChart(chartBuilder.build());
}

Параметры

Имя Тип Описание
columns Object[] Массив индексов столбцов или описаний столбцов (объект), которые необходимо включить в представление данных. Описания столбцов определяют роль столбца. Таблица данных и перечисление столбцов представления данных начинаются с нуля.

Возвращаться

DataViewDefinitionBuilder — Этот построитель полезен для создания цепочек вызовов.