Hojas de cálculo de Google es una solución de hojas de cálculo basada en la nube que admite la colaboración en tiempo real y proporciona herramientas para visualizar, procesar y comunicar datos.
En el siguiente ejemplo se muestra cómo escribir en Hojas de cálculo desde un flujo de trabajo. El flujo de trabajo consulta un conjunto de datos de BigQuery y escribe los resultados en una hoja de cálculo. Usa conectores de Workflows para simplificar las llamadas a las APIs de Google Cloud .
Antes de empezar
Antes de probar el ejemplo de este documento, asegúrate de que has completado lo siguiente.
Habilita las APIs Compute Engine, Google Drive, Hojas de cálculo de Google y Workflows.
Consola
gcloud
gcloud services enable \ compute.googleapis.com \ drive.googleapis.com \ sheets.googleapis.com \ workflows.googleapis.com
Anota la cuenta de servicio predeterminada de Compute Engine, ya que la asociarás al flujo de trabajo de ejemplo para hacer pruebas. Los proyectos nuevos en los que se ha habilitado la API Compute Engine tienen esta cuenta de servicio creada con el rol básico de editor de IAM y con el siguiente formato de correo:
PROJECT_NUMBER-compute@developer.gserviceaccount.com
Puedes encontrar el número de tu proyecto en la página Bienvenido de la consola Google Cloud o puedes obtenerlo de la siguiente forma:
gcloud projects describe PROJECT_ID
En los entornos de producción, te recomendamos que crees una cuenta de servicio y le asignes uno o varios roles de IAM que contengan los permisos mínimos necesarios y que sigas el principio de privilegio mínimo.
Crea una carpeta en Google Drive. Esta carpeta se usa para almacenar tu hoja de cálculo. Al configurar un permiso para la carpeta compartida, tu flujo de trabajo podrá escribir en la hoja de cálculo.
- Ve a drive.google.com.
- Haz clic en Nuevo > Nueva carpeta.
- Asigna un nombre a la carpeta.
- Haz clic en Crear.
- Haz clic con el botón derecho en la carpeta nueva y selecciona Compartir.
Añade la dirección de correo de la cuenta de servicio predeterminada de Compute Engine.
De esta forma, la cuenta de servicio tendrá acceso a la carpeta. Cuando asocies la cuenta de servicio a tu flujo de trabajo, este tendrá acceso de edición a cualquier archivo de la carpeta. Más información sobre cómo compartir archivos, carpetas y unidades
Selecciona el rol Editor.
Desmarca la casilla Notificar a los usuarios.
Haz clic en Compartir.
Crear una hoja de cálculo
Puedes crear una hoja de cálculo de cualquiera de las siguientes formas:
- Crear una hoja de cálculo con Hojas de cálculo de Google
- Crear una hoja de cálculo con el conector de la API de Hojas de cálculo de Google
No hay ninguna opción para crear una hoja de cálculo directamente en una carpeta específica mediante la API Hojas de cálculo de Google. Sin embargo, hay alternativas, como mover la hoja de cálculo a una carpeta específica después de crearla, como se hace en los siguientes ejemplos. Para obtener más información, consulta el artículo Trabajar con carpetas de Google Drive.
Crear una hoja de cálculo con Hojas de cálculo de Google
Cuando creas una hoja de cálculo con Hojas de cálculo de Google, se guarda en Google Drive. De forma predeterminada, la hoja de cálculo se guarda en la carpeta raíz de Drive.
Ve a sheets.google.com.
Haz clic en Nuevo
.
Al hacerlo, se abrirá una hoja de cálculo nueva. Cada hoja de cálculo tiene un valor
spreadsheetId
único que contiene letras, números, guiones o guiones bajos. Puedes encontrar el ID de hoja de cálculo en una URL de Hojas de cálculo de Google:https://docs.google.com/spreadsheets/d/spreadsheetId/edit#gid=0
Anota este ID, ya que lo necesitarás cuando crees el flujo de trabajo.
Mueve la hoja de cálculo a la carpeta de Google Drive que has creado anteriormente:
- En la hoja de cálculo, selecciona Archivo > Mover.
- Ve a la carpeta que has creado.
- Haz clic en Mover.
Crear una hoja de cálculo con el conector de la API de Hojas de cálculo de Google
Puedes usar el conector de la API de Hojas de cálculo de Google para crear una hoja de cálculo. Como Workflows usa la cuenta de servicio como identidad del activador, la hoja de cálculo se crea en la carpeta raíz de Google Drive de la cuenta de servicio. Después, puedes mover la hoja de cálculo a otra carpeta.
En el siguiente flujo de trabajo, el spreadsheetId
se obtiene del resultado resp
:
YAML
JSON
Sustituye FOLDER_ID
por el ID de la carpeta a la que quieras mover la hoja de cálculo. Cada carpeta de Drive tiene un ID único que contiene letras, números, guiones o guiones bajos. Puedes encontrar el ID de la carpeta en la URL de la carpeta:
https://drive.google.com/drive/folders/FOLDER_ID/edit#gid=0
Para obtener más información, consulta el artículo Crear y rellenar carpetas.
La salida del flujo de trabajo debería ser similar a la siguiente, donde el valor de id
es spreadsheetId
:
"body": { "id": "spreadsheetId", "kind": "drive#file", "mimeType": "application/vnd.google-apps.spreadsheet", "name": "Untitled spreadsheet" }
Consultar el conjunto de datos público de BigQuery
BigQuery aloja varios conjuntos de datos públicos que están disponibles para que el público en general los consulte.
En BigQuery, puedes ejecutar una tarea de consulta interactiva (bajo demanda). Por ejemplo, la siguiente consulta devuelve los 100 nombres más populares de un conjunto de datos específico y escribe el resultado en una tabla temporal. Esta es la consulta que ejecutará tu flujo de trabajo.
Consola
En la Google Cloud consola, ve a la página BigQuery.
Introduce la siguiente consulta de SQL de BigQuery en el área de texto Editor de consultas:
SELECT name, gender, SUM(number) AS total FROM `bigquery-public-data.usa_names.usa_1910_2013` GROUP BY name, gender ORDER BY total DESC LIMIT 100
Haz clic en Ejecutar.
bq
En el terminal, introduce el siguiente comando bq query
para ejecutar una consulta interactiva con la sintaxis de SQL estándar:
bq query \ --use_legacy_sql=false \ 'SELECT name, gender, SUM(number) AS total FROM `bigquery-public-data.usa_names.usa_1910_2013` GROUP BY name, gender ORDER BY total DESC LIMIT 100'
Desplegar un flujo de trabajo que escriba en Hojas de cálculo
Implementa un flujo de trabajo que consulte un conjunto de datos de BigQuery mediante el conector de la API BigQuery y que escriba los resultados en una hoja de cálculo de Hojas de cálculo mediante el conector de la API Google Sheets.
Consola
En la Google Cloud consola, ve a la página Flujos de trabajo:
Haz clic en
Crear.Escribe un nombre para el nuevo flujo de trabajo:
read-bigquery-write-sheets
.En la lista Región, selecciona us-central1 (Iowa).
En Cuenta de servicio, selecciona la cuenta de servicio predeterminada de Compute Engine (
PROJECT_NUMBER-compute@developer.gserviceaccount.com
).Haz clic en Siguiente.
En el editor del flujo de trabajo, introduce la siguiente definición para tu flujo de trabajo:
Sustituye el valor del marcador de posición
sheetId
por tuspreadsheetId
.Haz clic en Desplegar.
gcloud
Crea un archivo de código fuente para tu flujo de trabajo:
touch read-bigquery-write-sheets.yaml
En un editor de texto, copia el siguiente flujo de trabajo en tu archivo de código fuente:
Sustituye el valor del marcador de posición
sheetId
por tuspreadsheetId
.Para desplegar el flujo de trabajo, introduce el siguiente comando:
gcloud workflows deploy read-bigquery-write-sheets \ --source=read-bigquery-write-sheets.yaml \ --location=us-central1 \ --service-account=PROJECT_NUMBER-compute@developer.gserviceaccount.com
Sustituye
PROJECT_NUMBER
por el número de tu proyecto. Google Cloud Puedes encontrar el número de tu proyecto en la página Bienvenido de la consola de Google Cloud .
Ejecutar el flujo de trabajo y verificar los resultados
Al ejecutar un flujo de trabajo, se ejecuta la definición del flujo de trabajo actual asociada al flujo de trabajo.
Ejecuta el flujo de trabajo:
Consola
En la Google Cloud consola, ve a la página Flujos de trabajo:
En la página Flujos de trabajo, selecciona el flujo de trabajo read-bigquery-write-sheets para ir a su página de detalles.
En la página Detalles del flujo de trabajo, haz clic en play_arrow Ejecutar.
Vuelve a hacer clic en Ejecutar.
Consulta los resultados del flujo de trabajo en el panel Información.
La salida debería ser similar a la siguiente:
{ "spreadsheetId": "1pgkNY7mWICA6o6INUNLHGnmk0Tdioh0nUghZPOYPpZA", "updatedCells": 303, "updatedColumns": 3, "updatedRange": "Sheet1!A1:C101", "updatedRows": 101 }
gcloud
Abre la terminal.
Ejecuta el flujo de trabajo:
gcloud workflows run read-bigquery-write-sheets
Los resultados de la ejecución deberían ser similares a los siguientes:
Waiting for execution [4dcf737b-69d9-4081-b8d9-86d39ae86bd1] to complete...done. argument: 'null' duration: 3.131912897s endTime: '2023-01-25T14:59:46.818828242Z' name: projects/918619793306/locations/us-central1/workflows/read-bigquery-write-sheets/executions/4dcf737b-69d9-4081-b8d9-86d39ae86bd1 result: '{"spreadsheetId":"1pgkNY7mWICA6o6INUNLHGnmk0Tdioh0nUghZPOYPpZA","updatedCells":303,"updatedColumns":3,"updatedRange":"Sheet1!A1:C101","updatedRows":101}' startTime: '2023-01-25T14:59:43.686915345Z' state: SUCCEEDED
Comprueba que el flujo de trabajo haya escrito los resultados de la consulta en tu hoja de cálculo. Por ejemplo, el número de columnas y filas de la hoja de cálculo debe coincidir con los valores
updatedColumns
yupdatedRows
.
Siguientes pasos
- Activar un flujo de trabajo desde Hojas de cálculo de Google.
- Pausar y reanudar un flujo de trabajo mediante devoluciones de llamada y Hojas de cálculo de Google.
- Consulta el Centro de Aprendizaje de Google Workspace.