Sử dụng Trang tính liên kết

Trang tính liên kết là một tính năng của Google Trang tính, cho phép bạn phân tích dữ liệu BigQuery và Looker ngay trong Trang tính. Bạn có thể truy cập vào Các trang tính liên kết theo phương thức lập trình bằng dịch vụ Bảng tính.

Các thao tác thường dùng trong Trang tính liên kết

Sử dụng các lớp và đối tượng DataSource để kết nối với BigQuery hoặc Looker và phân tích dữ liệu. Bảng sau đây liệt kê các thao tác DataSource phổ biến nhất và cách tạo các thao tác đó trong Apps Script:

Hành động Lớp Google Apps Script Phương thức sử dụng
Kết nối một trang tính với một nguồn dữ liệu được hỗ trợ DataSourceSpec SpreadsheetApp.newDataSourceSpec()
Chọn một nguồn dữ liệu DataSource Spreadsheet.insertDataSourceSheet().getDataSource()
Thêm trang tính nguồn dữ liệu DataSourceSheet Spreadsheet.insertDataSourceSheet()
Thêm bảng tổng hợp DataSourcePivotTable Range.insertDataSourcePivotTable()
Kéo dữ liệu vào bản trích xuất DataSourceTable Range.insertDataSourceTable()
Sử dụng công thức DataSourceFormula Range.setFormula()
Thêm biểu đồ DataSourceChart Sheet.insertDataSourceChart()

Thêm phạm vi uỷ quyền bắt buộc

Để truy cập vào dữ liệu BigQuery, bạn phải đưa phương thức enableBigQueryExecution() vào mã Google Apps Script của mình. Phương thức này sẽ thêm phạm vi OAuth bigquery.readonly bắt buộc vào dự án Google Apps Script.

Mẫu sau đây cho thấy phương thức SpreadsheetApp.enableBigQueryExecution() được gọi trong một hàm:

function addDataSource() {
  SpreadsheetApp.enableBigQueryExecution();
  var spreadsheet = SpreadsheetApp.getActive();
  }

Để truy cập vào dữ liệu Looker, bạn phải đưa phương thức enableLookerExecution() vào mã Google Apps Script. Khi truy cập vào Looker trong Apps Script, bạn sẽ sử dụng lại đường liên kết trong Tài khoản Google mà bạn hiện có với Looker.

Mẫu sau đây cho thấy phương thức SpreadsheetApp.enableLookerExecution() được gọi trong một hàm:

function addDataSource() {
  SpreadsheetApp.enableLookerExecution();
  var spreadsheet = SpreadsheetApp.getActive();
  }

Thêm các phạm vi OAuth khác vào tệp kê khai

Khi kết nối với BigQuery, hầu hết các phạm vi OAuth sẽ tự động được thêm vào tệp kê khai dựa trên các hàm được sử dụng trong mã của bạn. Nếu cần thêm phạm vi để truy cập vào một số dữ liệu BigQuery nhất định, bạn có thể đặt phạm vi rõ ràng.

Ví dụ: để truy vấn dữ liệu BigQuery được lưu trữ trong Google Drive, bạn phải thêm phạm vi OAuth của Drive vào tệp kê khai.

Mẫu sau đây minh hoạ phần oauthScopes của tệp kê khai. Thêm một phạm vi OAuth của Drive ngoài các phạm vi OAuth spreadsheetbigquery.readonly tối thiểu bắt buộc:

{ ...
  "oauthScopes": [
    "https://www.googleapis.com/auth/bigquery.readonly",
    "https://www.googleapis.com/auth/spreadsheets",
    "https://www.googleapis.com/auth/drive" ],
... }

Ví dụ: Tạo và làm mới đối tượng nguồn dữ liệu

Các ví dụ sau đây cho biết cách thêm nguồn dữ liệu, tạo đối tượng nguồn dữ liệu từ nguồn dữ liệu đó, làm mới đối tượng nguồn dữ liệu và xem trạng thái thực thi.

Thêm nguồn dữ liệu

Các ví dụ sau đây cho thấy cách thêm nguồn dữ liệu BigQuery và nguồn dữ liệu Looker tương ứng.

BigQuery

Để thêm nguồn dữ liệu BigQuery vào bảng tính, hãy chèn trang tính nguồn dữ liệu có thông số nguồn dữ liệu. Trang tính nguồn dữ liệu sẽ tự động được làm mới để tìm nạp dữ liệu xem trước.

Thay thế <YOUR_PROJECT_ID> bên dưới bằng một mã dự án hợp lệ trên Google Cloud.

// For operations that fetch data from BigQuery, enableBigQueryExecution() must be called.
SpreadsheetApp.enableBigQueryExecution();
var spreadsheet = SpreadsheetApp.create('Test connected sheets');
Logger.log('New test spreadsheet: %s', spreadsheet.getUrl());

// Build data source spec by selecting a table.
var dataSourceSpec = SpreadsheetApp.newDataSourceSpec()
    .asBigQuery()
    .setProjectId('<YOUR_PROJECT_ID>')
    .setTableProjectId('bigquery-public-data')
    .setDatasetId('ncaa_basketball')
    .setTableId('mbb_historical_tournament_games')
    .build();
// Add data source and its associated data source sheet.
var dataSourceSheet = spreadsheet.insertDataSourceSheet(dataSourceSpec);
var dataSource = dataSourceSheet.getDataSource();

Looker

Để thêm nguồn dữ liệu Looker vào bảng tính, hãy chèn một trang tính nguồn dữ liệu có thông số nguồn dữ liệu. Trang tính nguồn dữ liệu sẽ tự động được làm mới để tìm nạp dữ liệu xem trước.

Thay thế <INSTANCE_URL>,<MODEL_NAME>, <EXPLORE_NAME> trong mẫu sau bằng URL thực thể Looker, tên mô hình và tên dữ liệu khám phá hợp lệ tương ứng.

// For operations that fetch data from Looker, enableLookerExecution() must be called.
SpreadsheetApp.enableLookerExecution();
var spreadsheet = SpreadsheetApp.create('Test connected sheets');
Logger.log('New test spreadsheet: %s', spreadsheet.getUrl());

// Build data source spec by selecting a table.
var dataSourceSpec = SpreadsheetApp.newDataSourceSpec()
    .asLooker()
    .setInstanceUrl('<INSTANCE_URL>')
    .setModelName('<MODEL_NAME>')
    .setExploreName('<EXPLORE_NAME>')
    .build();
// Add data source and its associated data source sheet.
var dataSourceSheet = spreadsheet.insertDataSourceSheet(dataSourceSpec);
var dataSource = dataSourceSheet.getDataSource();

Thêm đối tượng nguồn dữ liệu

Sau khi thêm nguồn dữ liệu vào bảng tính, bạn có thể tạo các đối tượng nguồn dữ liệu từ nguồn dữ liệu đó. Trong ví dụ này, bảng tổng hợp được tạo bằng cách sử dụng DataSourcePivotTable trên dataSource BigQuery được tạo trong mẫu mã thêm nguồn dữ liệu BigQuery.

Không giống như dữ liệu thông thường trong các trang tính lưới được tham chiếu theo chỉ mục ô hoặc ký hiệu A1, dữ liệu từ nguồn dữ liệu thường được tham chiếu theo tên cột. Do đó, hầu hết phương thức setter của thuộc tính trên đối tượng nguồn dữ liệu đều sử dụng tên cột làm dữ liệu đầu vào.

var rootCell = spreadsheet.insertSheet('pivotTableSheet').getRange('A1');

// Add data source pivot table and set data source specific configurations.
var dataSourcePivotTable = rootCell.createDataSourcePivotTable(dataSource);
var rowGroup = dataSourcePivotTable.addRowGroup('season');
rowGroup.sortDescending().setGroupLimit(5);
dataSourcePivotTable.addColumnGroup('win_school_ncaa');
dataSourcePivotTable.addPivotValue('win_pts', SpreadsheetApp.PivotTableSummarizeFunction.AVERAGE);
dataSourcePivotTable.addPivotValue('game_date', SpreadsheetApp.PivotTableSummarizeFunction.COUNTA);
var filterCriteria = SpreadsheetApp.newFilterCriteria()
    .whenTextEqualToAny(['Duke', 'North Carolina'])
    .build();
dataSourcePivotTable.addFilter('win_school_ncaa', filterCriteria);

// Get a regular pivot table instance and set shared configurations.
var pivotTable = dataSourcePivotTable.asPivotTable();
pivotTable.setValuesDisplayOrientation(SpreadsheetApp.Dimension.ROWS);

Làm mới đối tượng nguồn dữ liệu

Bạn có thể làm mới các đối tượng nguồn dữ liệu để tìm nạp dữ liệu mới nhất từ BigQuery dựa trên quy cách nguồn dữ liệu và cấu hình đối tượng.

Quá trình làm mới dữ liệu là không đồng bộ. Để làm mới một đối tượng nguồn dữ liệu, hãy sử dụng các phương thức sau:

  1. refreshData() bắt đầu thực thi quá trình làm mới dữ liệu.
  2. waitForCompletion() trả về trạng thái kết thúc sau khi quá trình thực thi dữ liệu hoàn tất. Điều này giúp bạn không cần phải tiếp tục thăm dò trạng thái thực thi.
  3. DataExecutionStatus.getErrorCode() nhận được mã lỗi trong trường hợp không thực thi được dữ liệu.

Mẫu bên dưới minh hoạ việc làm mới dữ liệu bảng tổng hợp:

var status = dataSourcePivotTable.getStatus();
Logger.log('Initial state: %s', status.getExecutionState());

dataSourcePivotTable.refreshData();

status = dataSourcePivotTable.waitForCompletion(/* timeoutInSeconds= */ 60);
Logger.log('Ending state: %s', status.getExecutionState());
if (status.getExecutionState() == SpreadsheetApp.DataExecutionState.ERROR) {
  Logger.log('Error: %s (%s)', status.getErrorCode(), status.getErrorMessage());
}

Sử dụng điều kiện kích hoạt với Trang tính liên kết

Tự động hoá các hàm nguồn dữ liệu Trang tính liên kết bằng điều kiện kích hoạt và sự kiện. Ví dụ: sử dụng trình kích hoạt dựa trên thời gian để làm mới các đối tượng nguồn dữ liệu nhiều lần tại một thời điểm cụ thể và sử dụng trình kích hoạt sự kiện của bảng tính để kích hoạt quá trình thực thi dữ liệu trên một sự kiện được xác định trước.

Mẫu sau đây thêm một nguồn dữ liệu BigQuery với một tham số truy vấn và làm mới trang tính nguồn dữ liệu khi thông số truy vấn được chỉnh sửa.

Thay thế <YOUR_PROJECT_ID> ở bên dưới bằng mã dự án hợp lệ trên Google Cloud.

// Add data source with query parameter.
function addDataSource() {
  SpreadsheetApp.enableBigQueryExecution();
  var spreadsheet = SpreadsheetApp.getActive();

  // Add a new sheet and use A1 cell as the parameter cell.
  var parameterCell = spreadsheet.insertSheet('parameterSheet').getRange('A1');
parameterCell.setValue('Duke');

  // Add data source with query parameter.
  var dataSourceSpec = SpreadsheetApp.newDataSourceSpec()
      .asBigQuery()
      .setProjectId('<YOUR_PROJECT_ID>')
      .setRawQuery('select * from `bigquery-public-data`.`ncaa_basketball`.`mbb_historical_tournament_games` WHERE win_school_ncaa = @SCHOOL')
      .setParameterFromCell('SCHOOL', 'parameterSheet!A1')
      .build();
  var dataSourceSheet = spreadsheet.insertDataSourceSheet(dataSourceSpec);
  dataSourceSheet.asSheet().setName('ncaa_data');
}

// Function used to configure event trigger to refresh data source sheet.
function refreshOnParameterEdit(e) {
  var editedRange = e.range;
if (editedRange.getSheet().getName() != 'parameterSheet') {
  return;
}
// Check that the edited range includes A1.
if (editedRange.getRow() > 1 || editedRange.getColumn() > 1) {
   return;
}

  var spreadsheet = e.source;
  SpreadsheetApp.enableBigQueryExecution();
  spreadsheet.getSheetByName('ncaa_data').asDataSourceSheet().refreshData();
}

Trong mẫu trên, hàm addDataSource() sẽ thêm một nguồn dữ liệu vào bảng tính. Sau khi bạn thực thi addDataSource(), hãy tạo một trình kích hoạt sự kiện trong trình chỉnh sửa Apps Script. Để tìm hiểu cách tạo một điều kiện kích hoạt sự kiện, hãy xem bài viết Điều kiện kích hoạt có thể cài đặt.

Chọn các tuỳ chọn sau cho điều kiện kích hoạt:

  • Nguồn sự kiện: Từ bảng tính
  • Loại sự kiện: Khi chỉnh sửa
  • Hàm cần chạy: refreshOnParameterEdit

Sau khi bạn tạo điều kiện kích hoạt, trang tính nguồn dữ liệu sẽ tự động làm mới mỗi khi bạn chỉnh sửa ô thông số.

Khắc phục sự cố

Thông báo lỗi Độ phân giải
Sử dụng enableBigQuery() để cho phép thực thi dữ liệu đối với nguồn dữ liệu BIGQUERY. Lỗi này cho biết rằng SpreadsheetApp.enableBigQueryExecution() không được gọi trước khi tìm nạp dữ liệu BigQuery.
Gọi SpreadsheetApp.enableBigQueryExecution() trong các hàm sử dụng phương thức thực thi BigQuery.
Chẳng hạn như refreshData() trên các đối tượng nguồn dữ liệu, Spreadsheet.insertDataSourceTable()DataSource.updateSpec().
Các phương thức này yêu cầu thêm phạm vi OAuth bigquery.readonly để hoạt động.
Không được phép thao tác đối với nguồn dữ liệu.
Vui lòng liên hệ với quản trị viên của bạn để bật tính năng này.
Lỗi này cho biết tài khoản chưa bật tính năng Trang tính liên kết.
Trang tính liên kết chỉ dành cho Google Workspace người dùng có một số gói thuê bao nhất định.
Liên hệ với quản trị viên để bật tính năng này.