Error Handling
Overview
Error handling with ETL is done slighly differently.
In Excel, for example, you have an IFERROR function, which works like this:
= IFERROR(value, value_if_error)
In Power Query, the approach for error handling is a little different. Consider the following example data:
data:image/s3,"s3://crabby-images/4f80f/4f80f505411b17a237d9ad10c619fab49171b31d" alt=""
From the above, we would like to create a new query that multiplies the values from the [Price] and [Amount] columns to create a new Subtotal column.
In the event an error is found in the Price column, we would like to use the [List Price] instead of the [Price] value.
This article explains how to do this.
Steps
1. Load the table as a query
The data should look something like this:
data:image/s3,"s3://crabby-images/c308e/c308e3777b3a5f25dfd4fa483d3876f79d442e14" alt=""
2. Add a custom column
- Add a custom column, with the following try / otherwise statement
data:image/s3,"s3://crabby-images/c2f7e/c2f7e559b83077a13394ae5a7787c0da2b58c0fd" alt=""
The result should look as follows:
data:image/s3,"s3://crabby-images/11de6/11de6059257f6aa9d182cc6b239a4d2f04e4adc5" alt=""
3. Error Messages
If you need to know why the error is occurring:
- Remove the step called ‘Changed Type’
- Add another custom column, using a try statement
data:image/s3,"s3://crabby-images/d874a/d874a29a2d273f21d7a35bf813e1119c9588d4ef" alt=""
- Load the following fields
data:image/s3,"s3://crabby-images/aae75/aae75ca3ffb4e8c4b427a5f147ee7eb17be149a3" alt=""
The table should look as follows:
data:image/s3,"s3://crabby-images/f17c4/f17c4176184330b58c73ca2901677f58be04ce68" alt=""
- Then expand the ‘Error’ column, and remove the ‘HasError’ and ‘Value’ columns
data:image/s3,"s3://crabby-images/2327d/2327da56fbfe3ddf7d0d8bd5b1ef2e554b8c6e8c" alt=""
The final table, with a message of what is causing the error, should be shown as follows:
data:image/s3,"s3://crabby-images/a50bf/a50bfb0deb381d5b76010d258bf038916f7bf596" alt=""
Using HasError
As shown below, when the try expression succeeds, the result includes a record in which HasError is false, and the Value field contains the result of the successful expression:
data:image/s3,"s3://crabby-images/02760/02760ebd329ee1d73afacaf21344f21535371096" alt=""
The following shows how errors can be programmatically handled without the use of the otherwise keyword:
let
Source = Excel.CurrentWorkbook(){[Name="Sample"]}[Content],
#"Added Custom" = Table.AddColumn(Source, "Record", each try[Price]),
#"Added Custom1" = Table.AddColumn(#"Added Custom", "Price.1", each if [Record][HasError] then null
else [Record][Value])
in
#"Added Custom1"
The expression returns null if the Price does not exist, and is similar to using a try/otherwise expression:
You can also show a custom message, if there is an error, using the following code:
let
Source = Excel.CurrentWorkbook(){[Name="Sample"]}[Content],
#"Added Custom" = Table.AddColumn(Source, "Record", each try[Price] otherwise error "Price is invalid")
in
#"Added Custom"
Feedback
Submit and view feedback