Compartilhar via


Errors

Um erro na linguagem de fórmulas do Power Query M é uma indicação de que o processo de avaliação de uma expressão não pôde produzir um valor. Os erros são gerados por operadores e funções que encontraram condições de erros ou usaram a expressão de erro. Os erros são tratados usando a expressão try. Quando um erro é gerado, é especificado um valor que pode ser usado para indicar por que o erro ocorreu.

Expressão try

Uma expressão try converte valores e erros em um valor de registro que indica se a expressão try tratou um erro ou não, bem como o valor apropriado ou o registro de erro que ela extraiu ao tratar o erro. Por exemplo, considere a seguinte expressão que gera um erro e o trata imediatamente:

try error "negative unit count"

Essa expressão avalia o seguinte valor de registro aninhado, explicando as pesquisas de campo [HasError], [Error] e [Message] no exemplo de preço unitário antes.

Registro de erro

[
    HasError = true,
    Error =
        [  
            Reason = "Expression.Error",
            Message = "negative unit count",
            Detail = null
        ]
]

Um caso comum é substituir erros por valores padrão. A expressão try também pode ser usada com uma cláusula opcional para obter apenas isso em um formato compacto:

try error "negative unit count" otherwise 42
// equals 42

Exemplo de erro

let Sales =
        [
        ProductName = "Fishing rod",
            Revenue = 2000,
            Units = 1000,
            UnitPrice = if Units = 0 then error "No Units"
                    else Revenue / Units
        ],

    //Get UnitPrice from Sales record
        textUnitPrice = try Number.ToText(Sales[UnitPrice]),
    Label = "Unit Price: " &
        (if textUnitPrice[HasError] then textUnitPrice[Error][Message]
        //Continue expression flow
            else textUnitPrice[Value])
in
    Label

O exemplo acima acessa o campo Sales[UnitPrice] e formata o valor, produzindo o seguinte resultado:

"Unit Price: 2"

Se o campo "Unidades" tivesse sido zero, o campo UnitPrice teria gerado um erro que teria sido tratado pela expressão try. O valor resultante teria sido:

"No Units"