# Export Workday workers to CSV with Python and upload to Google Drive recipe

This use case guides you through connecting Workday, Python snippets by Workato, and Google Drive to create a powerful automation.

# What does this recipe do?

This recipe performs a daily search for workers in Workday, converts the output data from JSON to CSV format using Python, and uploads the resulting CSV file to Google Drive.

flowchart TD subgraph Configuration[" "] direction TB subgraph Scheduler[&nbsp Scheduler by Workato New recurring event trigger &nbsp] Trigger(Trigger) --- setup1(setup) end subgraph Workday[&nbsp Workday Search business object batch action &nbsp] Action1(Action) --- setup2(setup) end subgraph Python[&nbsp Python snippets by Workato Execute code action &nbsp] Action2(Action) --- setup3(setup) end subgraph GoogleDrive[&nbsp Google Drive Upload file action &nbsp] Action3(Action) --- setup4(setup) end end CreateRecipe([Create recipe]) -- Configure your recipe --> Configuration --> Workflow([Automated workflow]) Scheduler --> Workday --> Python --> GoogleDrive classDef default fill:#fff,stroke:#67eadd,stroke-width:2px; classDef WorkatoTeal fill:#67eadd,stroke:#b3e0e1,stroke-width:2px,color:#000; classDef SubgraphDash fill:#e1fffc,stroke:#f66,stroke-width:2px,color:#000,stroke-dasharray: 5 5 class CreateRecipe,Trigger,setup1,Action1,setup2,Action2,setup3,Action3,setup4,Workflow WorkatoTeal class Scheduler,Workday,Python,GoogleDrive SubgraphDash

# Create your recipe

Complete the following steps to create a recipe that searches for workers in Workday, converts the output JSON data into CSV format using Python, and uploads the CSV file to Google Drive:

USE CASES ARE INTENDED AS EXAMPLES ONLY

This use case serves as an example. Modifications to triggers, actions, or conditional logic may be necessary to adapt this recipe to your workflow.

1

Sign in to Workato.

2

Select the project where you plan to create the recipe.

3

Create connections for Workday and Google Drive:

WORKATO UTILITY CONNECTORS DON'T REQUIRE SETUP

The Python snippets by Workato connector does not require connection setup.

Create a Workday connection.

# Before connecting to Workday

Before integrating with Workday using third-party services like Workato, we recommend using an Integration System User (ISU). Using an ISU ensures that all integration operations are logged under a designated user, separate from regular workflow processes. This is essential as changes to a regular worker’s security profile or their termination could disrupt integrations reliant on their account. For enhanced security, limit each ISU to a single integration system, such as Workato.

Additionally, if your integration involves custom objects in Workday, you must register a Workday API client. This step is required as the Workday REST API requires authentication through an OAuth client setup.

# Authentication requirements

The Workday connector supports both OAuth 2.0 and basic authentication methods. However, OAuth 2.0 authentication is required for working with the Workday REST API and custom objects. We recommend that you avoid using the deprecated Hybrid authentication method.

# Connection setup using OAuth 2.0 authentication

To configure your Workday connection in Workato using OAuth 2.0 authentication, complete the following steps:

1

Enter a unique Connection name to identify your Workday account in Workato.

Workday connection Label your connection

2

Choose OAuth 2.0 as the Authentication type. This method is required for working with custom objects and for querying data using Workday Query Language (WQL) with the Workday REST API.

3

Select the Workday web services version appropriate for your Workday tenant. We recommend choosing the newest version available for access to the latest features and updates.

4

Locate and enter your Tenant ID from the URL when logged into Workday. For example, in https://impl.workday.com/sample_company/d/home.htmld, the tenant ID is sample_company.

5

Provide the WSDL URL associated with your Workday services.

6

Enter the Client ID and Client Secret from your API client settings.

7

Optional. Input your Refresh token if you are using an API client for integrations.

8

Enter your Authorization endpoint and Token endpoint from your API Client settings to complete the OAuth flow.

9

Select the Workday tenant timezone that matches your Workday tenant's settings. By default, Workday uses Pacific Standard Time (PST).

10

Optional. Click Advanced settings to configure the Advanced XML payload for multiple ID values field.

By default, when constructing the XML from your input, Workato wraps each value in fields with multiple values within its own container.

For example:

<languages><language>english</language></languages><languages><language>chinese</language></languages>

If you set the value to Yes, Workato unwraps these values, presenting them in a single container:

<languages><language>english</language><language>chinese</language></languages>

Consider setting this field to Yes if you encounter invalid payload errors.

11

Review the information you entered to ensure it's correct.

12

Click Connect to initiate the authorization process and complete the connection setup.

# Connection setup using basic authentication

Complete the following steps to set up your Workday connection in Workato with basic authentication:

1

Enter a unique Connection name to identify your Workday account in Workato.

Workday connection Label your connection

2

Select Basic as the Authentication type. This method uses your Workday username and password for integration.

3

Select the Workday web services version appropriate for your Workday tenant. We recommend choosing the newest version available to access the latest features and updates.

4

Locate and enter your Tenant ID from the URL when logged into Workday. For example, if your URL is https://impl.workday.com/sample_company/d/home.htmld, the tenant ID is sample_company.

5

Provide the WSDL URL associated with your Workday services.

6

Input your Workday Login name and Password.

7

Select your Workday tenant timezone that matches your Workday tenant's settings. By default, Workday uses Pacific Standard Time (PST).

8

Click Advanced settings to configure the Advanced XML payload for multiple ID values field. By default, fields with multiple values are wrapped within a container. Set this option to yes to unwrap the values.

9

Review the information you entered to ensure it's correct.

10

Click Connect to initiate the authorization process and complete the connection setup.

Create a Google Drive connection.
1

Click Create > Connection.

2

Search for and select Google Drive on the New connection page.

3

Provide a name for your connection in the Connection name field.

Google Drive connection setupGoogle Drive

4

Use the Location drop-down menu to select the project where you plan to store the connection.

5

Use the Authentication type drop-down menu to select your authentication method. Options include OAuth 2.0 and Service account.

6

Optional. Expand Advanced settings to select permissions to request for the connection. By default, Workato requests the following permission:

  • See, edit, create, and delete all of your Google Drive files
7

Optional. Use the Custom OAuth profile drop-down menu to select the custom OAuth profile you plan to use for this connection.

8

Click Sign in with Google.

9

Select the account you plan to use to connect to Workato.

10

Review the requested permissions and click Allow.

4

Go back to your project and click Create > Recipe.

Create a new recipeCreate a new recipe

5

Enter a name for your recipe in the Name field.

6

Select the project where you plan to store the recipe from the Location drop-down menu.

7

Click Start building.

Start building your recipeStart building your recipe

8

Click Pick a starting point, then select Run on a schedule. This creates a new recipe with the Scheduler by Workato New recurring event trigger. This trigger doesn't require a connection.

9
Set up your Scheduler by Workato New recurring event trigger.
1

Click the trigger in the recipe editor.

Click the triggerClick the trigger

2

Use the Time unit drop-down menu to select Days.

  • Available options include Minutes, Hours, Days, Weeks, Months, or Custom schedule.
3

Enter 1 in the Trigger every field to run the recipe daily.

4

Specify the time for the recipe to run in the Trigger at field. For example, enter 12:00 AM.

5

Optional. Select the timezone in the Timezone field. If left blank, the default is America/Los_Angeles.

6

Optional. Set the start date and time in the Start after field, or leave it blank to activate the trigger immediately after you start the recipe. You can't change this value after you run or test the recipe.

Configure the triggerConfigure the trigger

7

Click Save.

Step summary

This trigger sets the interval for how frequently the recipe runs. The Scheduler by Workato trigger doesn't require connection setup.

10

Click + Add step and select Action in app.

Add actionClick Add step > Add action in app

11
Set up your Workday Search business object batch action.
1

Search for Workday and select it as your app.

Choose WorkdayChoose Workday

2

Select the Search business object (batch) action.

Select the Search business object actionSelect the Search business object action

3

Select the Workday connection you created in the preceding steps.

4

Use the Business object drop-down menu to select Workers.

Search for workers in WorkdaySearch for workers in Workday

5

Click Save.

Step summary

This step searches for workers in batches in Workday.

12

Click + Add step and select Action in app.

13
Set up your Python snippets by Workato Execute code action.
1

Search for Python snippets by Workato and select it as your app. The Execute code action is selected automatically, as it is the only available action for this connector.

Choose PythonChoose Python

2

Enter Convert JSON to CSV in the Name field to specify what this step does. This updates the action title in the recipe editor.

Specify the step purposeSpecify the step purpose

3

Go to Input fields and click Add field to open the Add new field dialog.

Add input fieldAdd input field

4

Enter JSON in the Label field.

5

Click Add field.

6

Switch the JSON field to formula mode and map the Workday Data Step 2 list datapill. Mapping this list datapill requires the field to be in formula mode.

7

Go to Output fields and click Add field to open the Add new field dialog.

8

Enter csv in the Label field.

9

Click Add field. This adds the csv field to the output schema:

Add the CSV output fieldAdd the CSV output field

10

Clear the content in the Code field.

11

Copy and paste the following Python code into the Code field:

# Import required libraries
import pandas as pd
import base64
import io

def main(input):
  # Normalize the JSON data to flatten nested structures into a flat table format
  normalized_json = pd.json_normalize(input['JSON'])
  
  # Remove the 'Worker_' prefix from all column names for cleaner headers
  normalized_json.columns = normalized_json.columns.str.replace('Worker_', '')

  # Drop any columns that contain 'Compensation_' in their name to exclude compensation data
  normalized_json = normalized_json[normalized_json.columns.drop(list(normalized_json.filter(regex='Compensation_')))]
  
  # Convert the modified DataFrame to CSV format as a string without the index column
  csv = normalized_json.to_csv(path_or_buf=None, index=False)
  
  # Return the CSV data as a dictionary output
  return { 'csv': csv }

This code takes a JSON input, normalizes it into a flat table format, removes Worker_ from the column names, excludes any columns containing Compensation_, and converts the resulting data into a CSV format. The code then returns the CSV content as a string.

12

Click Save.

Step summary

This step takes the Search workers in Workday step output, which is in JSON format, and converts it to CSV format using Python.

14

Click + Add step and select Action in app.

15
Set up your Google Drive Upload file action.
1

Search for Google Drive and select it as your app.

Choose Google DriveChoose Google Drive

2

Select the Upload file action.

Select the Upload file actionSelect the Upload file action

3

Map the Python snippets by Workato Csv Step 3 datapill to the File contents field.

Map the CSV datapillMap the CSV datapill

4

Switch the File name field to formula mode and enter the following:

"Workday-flattened-#{today}.csv"

This formula creates the name for the CSV file in the following format: Workday-flattened-YYYY-MM-DD.

Configure the file nameConfigure the file name

5

Use the Parent folder drop-down menu to select the folder where you plan to upload this file. This example selects a folder named Workday-workers-flattened as the parent folder.

6

Click Show optional fields and select Upload file MIME type.

7

Click Apply changes to show this field.

8

Enter text/csv in the Upload file MIME type field.

Specify the file typeSpecify the file type

9

Click Save.

Step summary

This step uploads the CSV output from the previous step to a folder you specify in Google Drive.

Your Export Workday workers to CSV with Python and upload to Google Drive recipe is ready to test and implement.

Example recipe configuration.

Workday, Python snippets by Workato, and Google Drive recipeExport Workday workers to CSV with Python and upload to Google Drive recipe


Last updated: 1/16/2025, 9:16:49 PM