Difference between revisions of "Expressions/pt-br"

From TaticView
Jump to: navigation, search
(Created page with "<div class="index-right">__TOC__</div>")
(Created page with "Sintaxe: COUNT_DISTINCT(<expressão>) Exemplo: '''COUNT_DISTINCT("Produto")''' - Retorna o número de ocorrências únicas de produtos")
 
(219 intermediate revisions by 4 users not shown)
Line 4: Line 4:
 
<div class="index-right">__TOC__</div>
 
<div class="index-right">__TOC__</div>
  
You can create expressions (formulas) directly in the dashboard components. It can thus display calculated values that are not present in the data source file/spreadsheet.
+
É possível criar expressões (fórmulas) diretamente nos componentes dos painéis. Podendo assim exibir valores calculados que não estão presentes no arquivo/planilha de origem dos dados.
  
  
To create the expression (formula) in the components, the component must support the addition of the special column ''Expression (Formula)''.
+
Para criar as expressões (fórmulas) nos componentes, é necessário que o componente suporte à adição da coluna especial ''Expressão (Fórmula)''.
  
  
In TaticView , all columns in the data file can be used in expressions as long as they are also added to the component that will receive the expression.
+
No TaticView, é possível utilizar nas expressões todas as colunas existentes no arquivo de dados, desde que estes sejam adicionados ao componente que receberá a expressão.
  
  
In addition, it is also possible to use fixed numbers and texts in the case of comparative expressions.
+
Além disso, também é possível utilizar números e textos fixos nos casos de expressões comparativas e ou cálculos matemáticos.
  
  
Expression Example:
+
Exemplo de expressão:
  
* If the component has the columns ''Total Price'' and ''Quantity'', you can create an expression to calculate the ''Unit Price''. Would be like this:
+
* Se o componente possui as colunas ''Preço Total'' e ''Quantidade'', pode-se criar uma expressão para calcular o ''Preço Unitário''. Ficaria assim:
** ''Total Price'' / ''Quantity''
+
** ''"Preço Total"'' / ''"Quantidade"''
* In addition, you can use fixed values, such as:
+
* Além disso, pode-se utilizar valores fixos, como por exemplo:
** ''Total price'' / 10
+
** ''"Preço Total"'' / 10
  
  
We just remember that currently TaticView only supports expressions whose numeric return.
+
Lembramos apenas que atualmente o TaticView suporta apenas expressões cujo retorno é numérico.
  
  
Below are details about how the expressions work:
+
As expressões suportam a barra inversa como [[EscapeChar|caractere de escape]] para que nomes possam conter os caracteres delimitadores.
  
== Basic structure of a Expression (Formula) ==
+
Abaixo detalhes sobre o funcionamento das expressões.
  
 +
== Estrutura básica de uma expressão ==
  
==== Value Operand ====
+
==== Identificador ====
  
It's the numerical values. You can use both while values and decimal values. For decimal values, the decimal separator should be the point.
+
É o nome do campo ou coluna envolvido na expressão, deve ser delimitado por aspas duplas.
  
* Examples: 1, 1.05, 2.55
+
* Exemplos: "Preço médio", "Parafuso 1\" philips", "Vendedor"
  
 +
==== Operando de Valor ====
  
==== Text Operand ====
+
São os valores numéricos. É possível utilizar tanto valores inteiros quanto valores decimais. Para valores decimais, o separador decimal deverá ser o ponto.
  
It's the text operands. If you want to use this type of operand in a expression, you must delimit them by the single quotation mark (').
+
* Exemplos: 1, 1.05, 2.55
  
* Examples: 'John Snow', 'California', 'Spaghetti'
+
* Importante: Não é permitido usar separador de milhar nos valores, assim como "," como separador decimal.
  
 +
==== Operando de Texto ====
  
==== Date Operand ====
+
São os operandos de texto. Para utilizar esse tipo de operando em uma expressão é necessário delimita-los pelo caractere aspa simples (').
  
These are values that express any date. To represent a date in expressions the behaviour is similar to text operands, i.e. the content must be surrounded by single quotation marks ('). However, the mask ''dd/MM/yyyy'' must be used.
+
* Exemplos: 'André Moraes', 'São Paulo', 'Espaguete'
  
* Examples: '01/01/2019', '14/11/2019', '25/12/2019'
 
  
 +
==== Operando de Data ====
  
==== Boolean Operand ====
+
São valores que expressam qualquer data. Para representar uma data nas expressões o comportamento é semelhante aos operandos de texto, ou seja, o conteúdo deve ser circundado por aspa simples ('). Porém deve-se utilizar a máscara ''dd/MM/aaaa''.
  
They're operators of the true or false type. Normally user to validate, or not, a condition in a more complex expression.
+
* Exemplos: '01/01/2019', '14/11/2019', '25/12/2019'
  
* Examples: true, false
 
  
 +
==== Operando Booleano ====
  
==== Parentheses ====
+
São operadores do tipo verdadeiro ou falso. Normalmente utilizados para validar, ou não, uma condição em uma expressão mais complexa.
  
Used to group and separate parts of on expression. Expressions within parentheses are processed first.
+
* Exemplos: true, false
  
* Example: ("Profit"/"Total Price") + 10
 
  
 +
==== Parênteses ====
  
==== System variable Operand ====
+
Utilizados para agrupar e separar partes de uma expressão. Expressões dentro de parênteses são processados antes das demais.
  
These are predefined variables in the system. To use the system variables you must precede them by hashtag (#) and delimit them by double quotes("). Currently only the "#null" variable is available and indicates null content.
+
* Exemplos: ("Lucro"/"Preço Total") + 10
  
* Example: IF("Product" == "#null";0;20)
 
  
 +
==== Operando de variável do sistema ====
  
== Arithmetic Expressions ==
+
São variáveis pré-definidas no sistema. Para utilizar as variáveis do sistema deve-se precede-las por hashtag (#) e delimita-las por aspas duplas ("). Atualmente apenas a variável ''"#null"'' está disponível e indica conteúdos nulos.
  
Arithmetic expressions relate two operands (which can be any the operands described above, or another expression) to make up the sum, subtraction, multiplication or division.
+
* Exemplo: IF("Produto" == "#null";0;20)
  
 +
== Expressões Aritméticas ==
  
==== Sum (+) ====
+
As expressões aritméticas relacionam dois operandos (que pode ser qualquer um dos operandos descritos acima, ou ainda outra expressão) para compor a soma, subtração, multiplicação ou divisão.
  
Add two value operands or another expression result. Represented by the ''+'' charecter.
 
  
Syntax:
+
==== Soma (+) ====
  <operating or expression result> '''+''' <operating or expression result>
 
Example:
 
  '''"Taxes" + "Commissions"''' - Sums the values of the fields ''Taxes'' and ''Commissions''
 
  
 +
Soma dois operandos de valor. Representado pelo caractere '''+'''.
  
==== Subtraction (-) ====
+
Sintaxe:
 +
  <operando ou expressão> + <operando ou expressão>
 +
Exemplo:
 +
  '''"Impostos" + "Comissões"''' – Soma os valores dos campos ''Impostos'' e ''Comissões''
  
Subtract two value operands or another expression result. Represented by the ''-'' charecter.
 
  
Syntax:
+
==== Subtração (-) ====
  <operating or expression result> '''-''' <operating or expression result>
 
Example:
 
  '''"Price" - "Taxes"''' - Subtracts the values ​​from the ''Price'' and ''Taxes'' fields.
 
  
 +
Subtrai dois operandos de valor ou o resultado de outra expressão. Representado pelo caractere '''-'''.
  
==== Multiplication (*) ====
+
Sintaxe:
 +
  <operando ou expressão> - <operando ou expressão>
 +
Exemplo:
 +
  '''"Preço" - "Impostos"''' – Subtrai os valores dos campos ''Preço'' e ''Impostos''
  
Multiplies two value operands or another expression result. Represented by the multiplication charecter ''*''.
 
  
Syntax:
+
==== Multiplicação (*) ====
  <operating or expression result> '''*''' <operating or expression result>
 
Example:
 
  '''"Quantity" * "Unit Price"''' - Multiplies the value of the ''Quantity'' field by the value of the ''Unit Price'' field.
 
  
 +
Multiplica dois operandos de valor ou resultados de outra expressão. Representado pelo caractere de multiplicação '''*'''.
  
==== Division (/) ====
+
Sintaxe:
 +
  <operando ou expressão> * <operando ou expressão>
 +
Exemplo:
 +
  '''"Quantidade" * "Preço Unitário"''' – Multiplica o valor do campo ''Quantidade'' pelo valor do campo ''Preço Unitário''
  
Divide two value operands or another expression result. Represented by the division charecter ''/''.
 
  
Syntax:
+
==== Divisão (/) ====
  <operating or expression result> '''/''' <operating or expression result>
 
Example:
 
  '''"Price" / "Quantity"''' - Divides the value of the ''Price'' field by the value of the ''Quantity'' field.
 
  
 +
Divide dois operandos de valor ou resultado de outras expressões. Representada pelo caractere de divisão '''/'''.
  
== Relational Expressions ==
+
Sintaxe:
 +
  <operando ou expressão> / <operando ou expressão>
 +
Exemplo:
 +
  '''"Preço" / "Quantidade"''' – Divide o valor do campo ''Preço'' pelo valor do campo ''Quantidade''
  
Relational expressions compare two operands (value/text or other expression) to assess whether a condition is true or false. Normally used with decision functions, such as ''IF''.
 
  
 +
== Expressões Relacionais ==
  
==== Equality (==) ====
+
As expressões relacionais comparam dois operandos (valor/texto ou outra expressão) para avaliar se uma condição é verdadeira (true) ou falsa (false). Normalmente utilizada com funções de decisão, como o ''IF'' (Se).
  
It compares if two operands are the same, returning true if they are the same or false if they are different. Represented by the equality operator ''==''.
 
  
Syntax:
+
==== Igualdade (==) ====
  <operating or expression result> '''==''' <operating or expression result>
 
Example:
 
  '''IF("Product" == "#null";0;20)''' - If the ''Product'' is null, return the value ''0''. Otherwise return the value ''20''
 
  
 +
Compara se dois operandos são iguais, retornando true se forem iguais ou false se diferentes. Representado pelo operador de igualdade '''=='''.
  
==== Different (!=) ====
+
Sintaxe:
 +
  <operando ou expressão> == <operando ou expressão>
 +
Exemplo:
 +
  '''IF("Produto" == "#null";0;20)''' – Se o produto for nulo, considera o valor ''0''. Caso contrário considera o valor ''20''
  
It compare if two operands are different, returning true if they were different or false if equal. Represented by the differente operator ''!=''.
 
  
Syntax:
+
==== Diferente (!=) ====
  <operating or expression result> '''!=''' <operating or expression result>
 
Example:
 
  '''IF("Product" != 'Lasagna';0;20)''' - If the ''Product'' is different from ''Lasagna'', return the value ''0''. Otherwise return the value ''20''
 
  
 +
Compara se dois operandos são diferentes, retornando true se foram diferentes ou false se iguais. Representado pelo operador de diferença '''!='''.
  
==== Greater than (>) ====
+
Sintaxe:
 +
  <operando ou expressão> != <operando ou expressão>
 +
Exemplo:
 +
  '''IF("Produto" != 'LASANHA';0;20)''' – Se o produto for diferente de ''Lasanha'', considera o valor ''0''. Caso contrário considera o valor ''20''
  
Compares if the first operator (from the left) is greater than the second operator (from the right), returning true if it is greater and false if it is lesser or equal. Represented by the greater operator ''>''.
 
  
Syntax:
+
==== Maior que (>) ====
    <operating or expression result> '''>''' <operating or expression result>
 
Example:
 
  '''IF("Gross Value" > 1000;1;0)''' - If the ''Gross Value'' is greater than ''1000'', returns the value ''1'', if not the value ''0''
 
  
 +
Compara se o primeiro operador (da esquerda) é maior que o segundo operador (da direita), retornando true se for maior e false se for menor ou igual. Representado pelo operador maior '''>'''.
  
==== Greater or equal to (>=) ====
+
Sintaxe:
 +
  <operando ou expressão> > <operando ou expressão>
 +
Exemplo:
 +
  '''IF("Valor Bruto" > 1000;1;0)''' – Se o ''Valor Bruto'' for maior que ''1000'', retorna o valor ''1'', se não o valor ''0''
  
Compares if the first operator (from the left) is greater or equal to the second operator (from the right), returning true if it is greater or equal and false if it is lesser. Represented by the greater or equal operator ''>=''.
 
  
Syntax:
+
==== Maior ou igual a (>=) ====
  <operating or expression result> '''>=''' <operating or expression result>
 
Example:
 
  '''IF("Gross Value" >= 2500;100;0)''' - If ''Gross Value'' is greater than or equal to ''2500'' returns ''100'', otherwise returns ''0''
 
  
 +
Compara se o primeiro operador (da esquerda) é maior ou igual ao segundo operador (da direita), retornando true se for maior ou igual e false se for menor. Representado pelo operador maior '''>='''.
  
==== Less than (<) ====
+
Sintaxe:
 +
  <operando ou expressão> >= <operando ou expressão>
 +
Exemplo:
 +
  '''IF("Valor Bruto" >= 2500;100;0)''' – Se o ''Valor Bruto'' for maior ou igual a ''2500'' retorna ''100'', caso contrário retorna ''0''
  
Compares if teh first operator (from the left) is lesser than the second operator (from the right), returning true if it is lesser and false if it is greater or equal. Represented by the Lesser operator ''<''.
 
  
Syntax:
+
==== Menor que (<) ====
  <operating or expression result> '''<''' <operating or expression result>
 
Example:
 
  '''IF("Gross Value" < 100;50;200)''' - If ''Gross Value'' is less than ''100'', returns ''50'' if not ''200''
 
  
 +
Compara se o primeiro operador (da esquerda) é menor que o segundo operador (da direita), retornando true se for menor e false se for maior ou igual. Representado pelo operador maior '''<'''.
  
==== Less or equal to (<=) ====
+
Sintaxe:
 +
  <operando ou expressão> < <operando ou expressão>
 +
Exemplo:
 +
  '''IF("Valor Bruto" < 100;50;200)''' – Se o ''Valor Bruto'' for menor que ''100'', retorna ''50'', se não retorna ''200''
  
Compares if the first operator (from the left) is lesser or equal to the second operator (from the right), returning true if it is lesser or equal and false if it is greater. Represented by the lesser or equal operator ''<=''.
 
  
Syntax:
+
==== Menor ou igual a (<=) ====
  <operating or expression result> '''<=''' <operating or expression result>
 
Example:
 
  '''IF("Gross Value" <= 500;100;0)''' - If ''Gross Value'' is less than or equal to ''500'' returns ''100'', if not ''0''
 
  
 +
Compara se o primeiro operador (da esquerda) é menor ou igual ao segundo operador (da direita), retornando true se for menor ou igual e false se for maior. Representado pelo operador maior '''<='''.
  
== Logical Expressions ==
+
Sintaxe:
 +
  <operando ou expressão> <= <operando ou expressão>
 +
Exemplo:
 +
  '''IF("Valor Bruto" <= 500;100;0)''' – Se o ''Valor Bruto'' for menor ou igual a ''500'' retorna ''100'', se não retorna ''0''
  
Logical expressions group together two operands (Boolean or other expression) to make up a logical expression, in order to evaluate the relationship of two Boolean operators to a true or false result. This type of expression is usually used for decision making, such as IF and with relational expressions.
 
  
 +
== Expressões Lógicas ==
  
==== And Operator (&&) ====
+
As expressões lógicas agrupam dois operandos (booleano ou outra expressão) para compor uma expressão lógica, com o objetivo de avaliar a relação de dois operadores booleanos em um resultado verdadeiro (true) ou falso (false). Normalmente esse tipo de expressão é utilizada para tomadas de decisão, como o ''IF'' (Se) e com expressões relacionais.
  
Executes the logical operation ''AND'' between two Boolean values. Both values must return true so that the result of the operation is true. Represented by the ''&&'' operator.
 
  
Syntax:
+
==== Operador E (&&) ====
  <expression> && <expression>
 
Examples:
 
  '''IF(("Price" > 0) && ("Seller" == 'John Snow');450;0)''' - If ''Price'' is greater than ''0'' '''AND''' ''Seller'' is equal to ''John Snow'', returns ''450'' if not returns ''0''
 
 
 
  '''IF(("City" != "#null") && ("Product" != 'Lasagna');1;0)''' - If ''City'' is non-null '''AND''' ''Product'' is different from ''Lasagna'' returns ''1'' if it does not return ''0''
 
  
 +
Executa a operação lógica ''E'' entre dois valores booleanos. Ambos os valores devem retornar verdadeiro (true) para que o resultado da operação seja verdadeiro (true). Representado pelo operador '''&&'''.
  
==== Or Operator (||) ====
+
Sintaxe:
 +
  <expressão> && <expressão>
 +
Exemplos:
 +
  '''IF(("Preço" > 0) && ("Vendedor" == 'André Moraes');450;0)''' – Se o ''Preço'' for maior que ''0'' '''E''' o ''Vendedor'' for igual a ''André Moraes'', retorna ''450'', se não retorna ''0''
 +
  '''IF(("Cidade" != "#null") && ("Produto" != 'Lasanha');1;0)''' – Se a ''Cidade'' for diferente de nula '''E''' o ''Produto'' for diferente de ''Lasanha'' retorna ''1'', se não retorna ''0''
  
Performs the logical ''OR'' operation between two Boolean values. A two values must be true so that the result of the operation is true. Represented by the operator ''||''.
 
  
Syntax:
+
==== Operador Ou (||) ====
  <expression> || <expression>
 
Examples:
 
  '''IF(("Price" > 1000) || ("Profit" >= 50);75;55)''' - If ''Price'' is greater than ''1000'' '''OR''' ''Profit'' is greater than or equal to ''50'' returns ''75'' if not ''55''
 
  
  '''IF(("City" != "#null") || ("Product" != 'Lasagna');1;0)''' - If ''City'' is non-null '''OR''' ''Product'' is different from ''Lasagna'' returns ''1'' if it does not return ''0''
+
Executa a operação lógica ''OU'' entre dois valores booleanos. Um dois dois valores deve ser verdadeiro (true) para que o resultado da operação seja verdadeiro (true). Representado pelo operador '''||'''.
  
 +
Sintaxe:
 +
  <expressão> || <expressão>
 +
Exemplos:
 +
  '''IF(("Preço" > 1000) || ("Lucro" >= 50);75;55)''' – Se o ''Preço'' for maior que ''1000'' '''OU''' o ''Lucro'' for maior ou igual a ''50'' retorna ''75'', se não retorna ''55''
 +
  '''IF(("Cidade" != "#null") || ("Produto" != 'Lasanha');1;0)''' - Se ''Cidade'' não for null '''OU''' ''Produto'' deferente de ''Lasanha'' returna ''1'' senão retorna ''0''
  
  
==== Denial Operator (!) ====
 
  
Performs the logical negation operation for a boolean value. If the result of the operation is true the negation operator converts to false and vice versa. Represented by the operator ''!''.
+
==== Operador de Negação (!) ====
  
Syntax:
+
Executa a operação lógica de negação para um valor booleano. Se o resultado da operação for verdadeiro (true) o operador de negação converte para falso (false) e vice-versa. Representado pelo operador '''!'''.
  !<expression>
 
Example:
 
  '''IF(!BETWEEN("Delivery Date"; '01/01/2015'; '31/12/2015');2016;2015)''' - If the ''Delivery Date'' is '''NOT''' between ''01/01/2015'' and ''12/31/2015'' returns ''2016''. If between this period returns ''2015''
 
  
 +
Sintaxe:
 +
  !<expressão>
 +
Exemplo:
 +
  '''IF(!BETWEEN("Data Entrega"; '01/01/2015'; '31/12/2015');2016; 2015)''' – Se a ''Data Entrega'' não tiver entre ''01/01/2015'' e ''31/12/2015'' retorna ''2016''. Se estiver entre esse período retorna ''2015''
  
== Auxiliary Functions ==
 
  
Basic helper functions are standard system functions and implement useful features for composing complex expressions.
+
== Funções Auxiliares ==
  
 +
As funções auxiliares básicas são funções padrão do sistema e implementam funcionalidades úteis para compor expressões complexas.
  
==== ABS function ====
 
  
Function that returns the absolute numeric value of a base numeric value.
+
==== Função ABS ====
  
Syntax:
+
Função que retorna o valor numérico absoluto de um valor numérico base.
  ABS(<value operator or expression>)
 
Example:
 
  '''ABS("Price" / "Quantity")''' - Returns the absolute value of ''Price'' divided by ''Quantity''
 
  
 +
Sintaxe:
 +
  ABS(<expressão>)
 +
Exemplo:
 +
  '''ABS("Preço" / "Quantidade")''' – Retorna o valor absoluto do ''Preço'' divido pela ''Quantidade''
  
==== AVG function ====
 
  
Returns the average of the values ​​of a sequence of values. It can be used to return the average of different values ​​of the same row of tables.
+
==== Função AVG ====
  
Syntax:
+
Retorna a média dos valores de uma sequência de valores. Pode ser utilizado para retornar a média de diferentes valores de uma mesma linha das tabelas.
  AVG(<expression 1>; <expression 2>; ...)
 
Example:
 
  '''AVG("Taxes"; "Profit"; "Cost")''' - Returns the average between the sum of the ''Taxes'', ''Profit'' and ''Cost'' columns
 
  
 +
Sintaxe:
 +
  AVG(<expressão 1>; <expressão 2>; ...)
 +
Exemplo:
 +
  '''AVG("Impostos"; "Lucro"; "Custo")''' – Retorna a média entre a soma das colunas ''Impostos'', ''Lucro'' e ''Custo''
  
==== BETWEEN function ====
 
  
Checks whether a value is within the limits of the parameters used. Return true or false.
+
==== Função BETWEEN (Entre) ====
  
Syntax:
+
Verifica se um valor está estre os limites dos parâmetros utilizados.
  BETWEEN(<expression to be tested>; <initial limit>; <end limit>)
 
Example:
 
  '''BETWEEN("Date Issued"; '01/01/2019'; '31/12/2019')''' - Returns true if ''Date Issued'' is between ''01/01/2019'' and ''12/31/2019''. Otherwise returns false
 
  
 +
Sintaxe:
 +
  BETWEEN(<expressão a ser testada>; <limite inicial>; <limite final>)
 +
Exemplo:
 +
  '''BETWEEN("Data Emissão"; '01/01/2019'; '31/12/2019')''' – Retorna true se a ''Data Emissão'' estiver entre ''01/01/2019'' e ''31/12/2019''. Caso contrário retorna false
  
==== IF ELSE function (If .... Otherwise ...) ====
+
==== Função COUNT ====
  
Tests a Boolean expression and applies a condition to true or another condition to false. You need three parameters, separated by semicolons (;). The first parameter is the expression to be tested, the second the value to be applied in case of true, and the third to be applied in case of false.
+
Retorna o número de ocorrências (linhas) de uma coluna ou valor.
  
Syntax:
+
Por ora, esta função funciona apenas em expressões de Fontes de Dados
  IF(<expression to be tested>; <expression if true>; <expression if false>)
 
Examples:
 
  '''IF(BETWEEN("Value";0;100);10;250)''' - If ''Value'' is between ''0'' and ''100'' returns ''10'', if not ''250''
 
  
   '''IF("Profit" == 0;0;"Profit" + "Taxes")''' - If ''Profit'' equals ''0'' returns ''0'', if it does not return the sum between ''Profit'' and ''Taxes''
+
Sintaxe:
 +
  COUNT(<expressão>)
 +
Exemplo:
 +
   '''COUNT("Produto")''' - Retorna o número de ocorrências (linhas) de produtos
  
 +
==== Função COUNT_DISTINCT ====
  
==== LOG function ====
+
Retorna o número de ocorrências únicas (linhas) de uma coluna ou valor.
  
Returns the logarithm of a number on a defined basis. It can be used with only one parameter, in this case the neperian (natural) logarithm is used . If two parameters are used, the second server to inform the base to be used by the logarithm.
+
Por ora, esta função funciona apenas em expressões de Fontes de Dados
  
Syntax:
+
Sintaxe:  
   LOG(<expression>;<base>)
+
   COUNT_DISTINCT(<expressão>)  
Examples:
+
Exemplo:  
   '''LOG("Profit")'''- Returns the logarithm of the field ''Profit''
+
   '''COUNT_DISTINCT("Produto")''' - Retorna o número de ocorrências únicas de produtos
  
  '''LOG("Price";2)''' - Returns the logarithm of the ''Price'' field in base ''2''
+
==== Função IF ELSE (Se.... Senão...) ====
  
 +
Testa uma expressão booleana e aplica uma condição em caso verdadeiro (true) ou outra condição nos casos de retornar falso (false). Precisa de três parâmetros, separados por ponto e virgula (;). O primeiro parâmetro é a expressão a ser testada, o segundo o valor a ser aplicado no caso de verdadeiro e o terceiro para ser aplicado no caso de falso.
  
==== MAX function ====
+
Sintaxe:
 +
  IF(<expressão a ser testada>; <expressão no caso de verdadeiro>; <expressão no caso de falso>)
 +
Exemplos:
 +
  '''IF(BETWEEN("Valor"; 0; 100); 10; 250)''' – Se o ''Valor'' estiver entre ''0'' e ''100'' retorna ''10'', se não retorna ''250''
 +
  '''IF("Lucro" == 0;0;"Lucro" + "Impostos")''' - Se ''Lucro'' igual a ''0'' retorna ''0'', senão retorna a soma de ''Lucro'' e ''Impostos''
 +
  '''IF("Código Produto" == 3231;0;"Quantidade" * 3;"Quantidade")''' - Se ''Código Produto'' igual a ''3231'' retorna ''Quantidade'' vezes 3
  
Returns the largest value between two values.
+
==== Função LOG ====
  
Syntax:
+
Retorna o logaritmo de um número em uma base definida. Pode ser utilizada com apenas um parâmetro, neste caso é utilizado o logaritmo na base 10. Caso seja utilizado dois parâmetros, o segundo serve para informar a base a ser utilizada pelo logaritmo.
  MAX(<expression 1>;<expression 2>)
 
Example:
 
  '''"Value" / MAX("Quantity";1)''' - Divides ''Value'' by the largest value between ''Quantity'' and ''1''
 
  
 +
Sintaxe:
 +
  LOG(<expressão>; <base>)
 +
Exemplos:
 +
  '''LOG("Lucro")''' – Retorna o logaritmo do campo ''Lucro''
 +
  '''LOG("Preço";2)''' - Retorna o logaritmo do campo ''Preço'' na base ''2''
  
==== MIN function ====
 
  
Returns the smallest value between two values.
+
==== Função MAX ====
  
Syntax:
+
Retorna o maior valor entre dois valores.
  MIN(<expression 1>; <expression 2>)
 
Example:
 
  '''"Value" / MIN("Cost"; 100)''' - Divides ''Value'' by the smallest value between ''Cost'' and ''100''
 
  
 +
Sintaxe:
 +
  MAX(<expressão 1>; <expressão 2>)
 +
Exemplo:
 +
  '''"Valor" / MAX("Quantidade"; 1)''' – Divide o ''Valor'' pelo maior valor entre a ''Quantidade'' e ''1''
  
==== POWER function ====
 
  
Returns the power of a value in a defined exponent. It can be used with only one parameter, in this case it considers the default exponent 2. If a second parameter is passed, this will be the exponent.
+
==== Função MIN ====
  
Syntax:
+
Retorna o menor valor entre dois valores.
  POW(<expression>; <exponent>)
 
Examples:
 
  '''POW("Profit")''' - Returns the power of the ''Profit'' value.
 
  
   '''POW("Cost"; 3)''' - Returns the power of the ''Cost'' value, raised to ''3''
+
Sintaxe:
 +
  MIN(<expressão 1>; <expressão 2>)
 +
Exemplo:
 +
   '''"Valor" / MIN("Custo"; 100)''' – Divide o ''Valor'' pelo menor valor entre ''Custo'' e ''100''
  
  
==== RANDOM function ====
+
==== Função POTENCIA ====
  
Returns a random number within the range of values ​​passed as arguments.
+
Retorna a potência de um valor em um expoente definido. Pode ser utilizada com apenas um parâmetro, neste caso considera o expoente padrão 2. Se um segundo parâmetro for passado, esse será o expoente.
  
Syntax:  
+
Sintaxe:
   RANDOM(<start limit>; <end limit>)
+
   POW(<expressão>; <expoente>)
Example:  
+
Exemplos:  
   '''RANDOM(10,100)''' - Returns a random number between ''10'' and ''100''
+
   '''POW("Lucro")''' – Retorna a potência do valor ''Lucro''
 +
  '''POW("Custo"; 3)''' - Retorna a potência do calor ''Custo'' elevado na terceira
  
  
==== SQRT function (Square Root) ====
+
==== Função RANDOM ====
  
Returns the square root of a value.
+
Retorna um número aleatório dentro dos limites dos valores passados como argumentos.
  
Syntax:  
+
Sintaxe:
   SQRT(<value or expression>)
+
   RANDOM(<limite inicial>; <limite final>)
Examples:
+
Exemplo:
   '''SQRT("Profit")''' - Returns the square root of the value ''Profit''
+
   '''RANDOM(10; 100)''' – Retorna um número aleatório entre ''10'' e ''100''
  
  '''SQRT(81)''' - Returns the square root of ''81''
+
==== Função ROUND ====
  
 +
Retorna o arredondamento de uma coluna de valor ou valor.
  
==== LIKE function ====
+
Sintaxe:
 +
  ROUND(<valor>;<precisão>)
 +
Exemplo:
 +
  '''ROUND("Lucro")''' - Se lucro for 10.38 retorna 10.00
 +
  '''ROUND(15.65)''' - Retorna 16.00
 +
  '''ROUND(1.777;1)''' - Retorna 1.8
  
Returns true if the desired content is found in the list and false otherwise. It needs two parameters, the first is the data to query and the second is the term to be found. Remembering that it is necessary to use the wildcard operator “%” and surround the term by single quotation mark.
+
==== Função SQRT (Raiz Quadrada) ====
  
Syntax:
+
Retorna a raiz quadrada de um valor.
  LIKE(< data>; <term>)
 
Example:
 
  '''LKE("Product"; '%anh%')''' - Returns true if the ''Product'' contains the term ''anh'' or false otherwise
 
  
 +
Sintaxe:
 +
  SQRT(<valor ou expressão>)
 +
Exemplos:
 +
  '''SQRT("Lucro")''' – Retorna a raiz quadrada do valor ''Lucro''
 +
  '''SQRT(81)''' - Retorna a raiz quadrada de ''81''
  
== Date Functions ==
 
  
Date functions are operations that take a date as a parameter and also return a date. There are some constants to assist in using date functions, they are:
+
==== Função LIKE (Contém) ====
  
* 0: ''DATE_FIELD_YEAR'' (Part of the year)
+
Retorna verdadeiro (true) se o conteúdo desejado for encontrado na lista e falso (false) caso contrário. Precisa de dois parâmetros, o primeiro são os dados que serão consultados e o segundo é o termo a ser encontrado. Lembrando que é necessário utilizar o operador de curinga ''%'' e circundar o termo por aspa simples.
* 1: ''DATE_FIELD_MONTH'' (Month Part)
 
* 2: ''DATE_FIELD_DAY'' (Daypart)
 
* 3: ''DATE_FIELD_FORTNIGHT'' (Part of fortnight)
 
* 5: ''DATE_FIELD_WEEK'' (Part of the Week)
 
  
 +
Sintaxe:
 +
  LIKE(<dados>; <termo>)
 +
Exemplo:
 +
  '''LIKE("Produto"; '%anh%')''' – Retorna true se o ''Produto'' contém o termo ''anh'' ou false caso contrário
 +
  '''LIKE("Produto"; '%anh%')''' - Retorna verdadeiro se o ''Produto'' conter a string ''anh'', caso contrário falso
  
==== DATE_PART function (Date Part) ====
+
== Funções de Data ==
  
Returns part of a date. It needs two parameters, the first is the reference date and the second is the constant that represents which part of the date we want to get.
+
As funções de data são operações que usam como parâmetro uma data e retornam também uma data. Existem algumas constantes para auxiliar na utilização das funções de data, são elas:
  
Syntax:  
+
* 0: ''DATE_FIELD_YEAR'' (Parte do ano)
  DATE_ PART(<date>; <constant representing which part>)
+
* 1: ''DATE_FIELD_MONTH'' (Parte do mês)
Example:  
+
* 2: ''DATE_FIELD_DAY'' (Parte do dia)
  '''DATE_ PART("Issued Date"; 0)''' - Returns the year portion of the ''Issued Date''
+
* 3: ''DATE_FIELD_FORTNIGHT'' (Parte da quinzena)
 +
* 5: ''DATE_FIELD_WEEK'' (Parte da semana)
  
  
==== DAY_FROM_TODAY function (Days from today) ====
+
==== Função DATE_PART (Parte da data) ====
  
Returns a days count backward (negative) or forward (positive) from today. You need a parameter that indicates the number of days to add or subtract.
+
Retorna parte de uma data. Precisa de dois parâmetros, o primeiro é a data de referência e o segundo é a constante que representa qual parte da data queremos obter.
  
Syntax:  
+
Sintaxe:
   DAY_FROM_TODAY(<number of days>)
+
   DATE_PART(< data>; <constante que representa qual parte>)
Example:  
+
Exemplo:
   '''DAY_FROM_TODAY(-1)''' - Returns yesterday's date
+
   '''DATE_PART("Data Emissão"; 0)''' - retorna a parte do ano da ''Data Emissão''
  
  
==== FIRST_DAY_OF function (First day of) ====
+
==== Função DAY_FROM_TODAY (Dias a partir de hoje) ====
  
Returns the first day of a grouping. This function has two variations:
+
Retorna uma contagem de dias para trás (negativa) ou para frente (positiva) contando a partir de hoje. Precisa de um parâmetro que indica o número de dias para adicionar ou subtrair.
  
* With two parameters, the first is the grouping constant from which we want to get the first date (see list above), and the second is the base date.
+
Sintaxe:
 +
  DAY_FROM_TODAY(<número de dias>)
 +
Exemplo:
 +
  '''DAY_FROM_TODAY(-1)''' - retorna a data de ontem
  
Syntax:
 
  FIRST_DAY_OF(<date part>; <base date>)
 
Examples:
 
  '''FIRST_DAY_OF(0;DAY_FROM_TODAY(0))''' - Returns the first day of the year from today
 
  
  '''FIRST_DAY_OF(1;"Issue Date")''' - First Day of Month Based on ''Issue Date'' Column
+
==== Função FIRST_DAY_OF (Primeiro dia de) ====
  
* With three parameters, the first is the grouping constant from which we want to get the first date (see list above), the second is the date base modifier from today, and the third is the amount to change the modifier.
+
Retorna o primeiro dia de um agrupamento. Esta função possui duas variações:
  
Syntax:
+
* Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), e o segundo é a data base.
  FIRST_DAY_OF(<date part>;<date modifier>;<date modifier value>)
 
Example:
 
  '''FIRST_DAY_OF(1,0,-1)''' - first day of current month of last year
 
  
 +
Sintaxe:
 +
  FIRST_DAY_OF(<parte da data>; < data base>)
 +
Exemplos:
 +
  '''FIRST_DAY_OF(0; DAY_FROM_TODAY(0))''' – retorna o primeiro dia do ano a partir de hoje
 +
  '''FIRST_DAY_OF(1;"Data Problema")''' - retorna o primeiro dia baseado na coluna ''Data Problema''
  
==== LAST_DAY_OF function (Last day of) ====
+
* Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.
  
Returns the last day of a date grouping. This function has two variations.
+
Sintaxe:
 +
  FIRST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)
 +
Exemplo:
 +
  '''FIRST_DAY_OF(1; 0; -1)''' – primeiro dia do mês atual do último ano
  
* With two parameters, the first is the grouping constant from which we want the last date (see list above), and the second is the base date.
 
  
Syntax:
+
==== Função LAST_DAY_OF (Último dia de) ====
  LAST_DAY_OF(<date part>; <base date>)
 
Examples:
 
  '''LAST_DAY_OF(0;DAY_FROM_TODAY(0))''' - Returns the last day of the year from today.
 
  
  '''LAST_DAY_OF(1;"Date Issued")''' - Last day of month based on ''Date Issued'' column
+
Retorna o último dia de um agrupamento de data. Esta função possui duas variações.
  
* With three parameters, the first is the grouping constant from which we want the last date (see list above), the second is the date base modifier from today, and the third is the amount to change the modifier.
+
* Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), e o segundo é a data base.
  
Syntax:  
+
Sintaxe:
   LAST_DAY_OF(<date part>;<date modifier>;<date modifier value>)
+
   LAST_DAY_OF(<parte da data>; < data base>)
Example:  
+
Exemplos:  
   '''LAST_DAY_OF(1,0,-1)''' - last day of current month of last year
+
   '''LAST_DAY_OF(0; DAY_FROM_TODAY(0))''' – retorna o último dia do ano a partir de hoje
 +
'''LAST_DAY_OF(1;"Date Problema")''' - retorna o último dia do mês baseado na coluna ''Data Problema''
  
 +
* Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.
  
==== NEW_DATE function (New date) ====
+
Sintaxe:
 +
  LAST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)
 +
Exemplo:
 +
  '''LAST_DAY_OF(1; 0; -1)''' – último dia do mês atual do último ano
  
Creates a new date. It needs three parameters, the first corresponds to the day (between 1 and 31), the second month (between 1 and 12) and the third the year. The date is created from year to day, ie the day must be valid for the month and year (considering 29/02, the year must be leap).
 
  
Syntax:
+
==== Função NEW_DATE (Nova data) ====
  NEW_DATE(<day>;<month>;<year>)
 
Example:
 
  '''NEW_DATE(1;4;DATE_PART("Issued Date";0))''' - Creates the first April day of the year determined by the current row in the ''Issued Date'' column.
 
  
 +
Cria uma nova data. Precisa de três parâmetros, o primeiro corresponde ao dia (entre 1 e 31), o segundo mês (entre 1 e 12) e o terceiro o ano. A data é criada do ano para o dia, ou seja, o dia deve ser válido para o mês e ano (considerando 29/02, o ano deve ser bissexto).
  
==== NUM_OF_DAYS function (Number of days) ====
+
Sintaxe:
 +
  NEW_DATE(<dia>; <mês>; <ano>)
 +
Exemplo:
 +
  '''NEW_DATE(1; 4; DATE_PART("Data Emissão"; 0))''' – cria o primeiro dia de abril do ano determinado pela linha atual da coluna ''Data Emissão''
  
Returns the number of days between two dates. Therefore you need two dates.
 
  
Syntax:
+
==== Função NUM_OF_DAYS (Número de dias) ====
  NUM_OF_DAYS(<date 1>; <date 2>)
 
Examples:
 
  '''NUM_OF_DAYS(FIRST_DAY_OF(0;"Issued Date");"Issued Date")''' - Returns the number of days from the first day of the year, based on the ''Issued Date'' column, to the current day, based on the same column.
 
  
  '''NUM_OF_DAYS(FIRST_DAY_OF(1;"Issued Date");LAST_DAY_OF(1,"Issued Date"))''' - Returns the number of days of the month, based on the ''Issued Date'' column.
+
Retorna o número de dias entre duas datas. Portanto necessita de duas datas.
  
 +
Sintaxe:
 +
  NUM_OF_DAYS(< data 1>; < data 2>)
 +
Exemplos:
 +
  '''NUM_OF_DAYS(FIRST_DAY_OF(0; "Data Emissão"); "Data Emissão")''' – retorna o número de dias entre o primeiro dia do ano, baseado na coluna ''Data Emissão'', até o dia atual, baseado na mesma coluna
 +
  '''NUM_OF_DAYS(FIRST_DAY_OF(1;"Data Pedido");LAST_DAY_OF(1;"Data Pedido"))''' - retorna o número de dias do mês baseado na coluna ''Data Pedido''.
  
==== NUM_OF_MONTHS function (Number of months) ====
 
  
Returns the number of months between two dates. Therefore, two date parameters are required.
+
==== Função NUM_OF_MONTHS (Número de Meses) ====
  
Syntax:
+
Retorna o número de meses entre duas datas. Logo, dois parâmetros data são exigidos.
  NUM_OF_MONTHS(<date 1>; <date 2>)
 
Example:
 
  '''NUM_OF_MONTHS(FIRST_DAY_OF(0; "Date"); "Date")''' - Returns the number of months between the first day of the year and the current month, based on the ''Date'' column.
 
  
 +
Sintaxe:
 +
  NUM_OF_MONTHS(< data 1>; < data 2>)
 +
Exemplo:
 +
  '''NUM_OF_MONTHS(FIRST_DAY_OF(0; "Data"); "Data")''' – Retorna o número de meses entre o primeiro dia do ano e o mês atual, com base na coluna ''Data''
  
==== PREVIOUS_DATE function (Previous date) ====
 
  
Given a day and a month, returns the last occurrence of that date. That is, if the current date (today) is less than the date passed by parameter (day / month), the return is the date (passed by parameter) of the previous year. Otherwise the return will be the current year date.
+
==== Função PREVIOUS_DATE (Data anterior) ====
  
Syntax:
+
Dado um dia e um mês, retorna a última ocorrência dessa data. Ou seja, se a data atual (hoje) for menor do que a data passada por parâmetro (dia/mês), o retorno será a data (passada por parâmetro) do ano anterior. Se não o retorno será a data do ano atual.
  PREVIOUS_DATE(<day>; <month>)
 
Examples:
 
  '''PREVIOUS_DATE(15;12)''' - Considering that today's date is 14/11/2019, the last time December 15th occurred relative to today's date was 15/12/2018, so this will be the return.
 
  
 +
Sintaxe:
 +
  PREVIOUS_DATE(<dia>; <mês>)
 +
Exemplos:
 +
  '''PREVIOUS_DATE(15;12)''' – Considerando que a data de hoje seja 14/11/2019, a última vez que 15/Dezembro ocorreu em relação a data de hoje foi 15/12/2018, logo esse será o retorno.
  
== Special Variables ==
 
  
They can be used in conjunction with expressions to create complex calculations. Must be used in double quotation marks (“)
+
== Variáveis Especiais ==
  
 +
Podem ser usadas em conjunto com as expressões para criar cálculos complexos. Devem ser utilizadas entre aspas duplas ('''"''')
  
* '''"@count"''' - Total number of rows that were returned for the component.
+
 
* '''"@row"''' - Current row number
+
* '''"@count"''' – Número total de linhas que foram retornadas para o componente
* '''"@sum[column]"''' - Sum of the indicated column.
+
* '''"@row"''' – Número da linha atual
** Example: ''"@sum[Price]"'' - returns the sum of all rows in the ''Price'' column.
+
* '''"@sum[coluna]"''' – Somatório da coluna indicada.
* '''"@avg[column]"''' - Average column, similar to ''"@sum[column]"'' / ''"@count"''
+
** Exemplo: ''"@sum[Preço]"'' – retorna a soma de todas as linhas da coluna ''Preço''
* '''"@prev[column]"''' - Row value before current row for this column
+
* '''"@avg[coluna]"''' – Média da coluna, semelhante a ''"@sum[coluna]"'' / ''"@count"''
* '''"@accumCol[column]"''' - Cumulative value from column to current row. Useful for calculating variable mean.
+
* '''"@prev[coluna]"''' – Valor da linha anterior à linha atual, para essa coluna
** Example: ''"@accumCol[column]"'' / ''"@row"''
+
* '''"@totalRowValue[coluna]"''' - Valor da Linha de Total, (se presente), para essa coluna.
 +
* '''"@accumCol[coluna]"''' – Valor acumulado da coluna até a linha corrente. Útil para calcular média variável.  
 +
** Exemplo: ''"@accumCol[coluna]"'' / ''"@row"''

Latest revision as of 03:20, 5 October 2022

Other languages:
English • ‎português do Brasil


É possível criar expressões (fórmulas) diretamente nos componentes dos painéis. Podendo assim exibir valores calculados que não estão presentes no arquivo/planilha de origem dos dados.


Para criar as expressões (fórmulas) nos componentes, é necessário que o componente suporte à adição da coluna especial Expressão (Fórmula).


No TaticView, é possível utilizar nas expressões todas as colunas existentes no arquivo de dados, desde que estes sejam adicionados ao componente que receberá a expressão.


Além disso, também é possível utilizar números e textos fixos nos casos de expressões comparativas e ou cálculos matemáticos.


Exemplo de expressão:

  • Se o componente possui as colunas Preço Total e Quantidade, pode-se criar uma expressão para calcular o Preço Unitário. Ficaria assim:
    • "Preço Total" / "Quantidade"
  • Além disso, pode-se utilizar valores fixos, como por exemplo:
    • "Preço Total" / 10


Lembramos apenas que atualmente o TaticView suporta apenas expressões cujo retorno é numérico.


As expressões suportam a barra inversa como caractere de escape para que nomes possam conter os caracteres delimitadores.

Abaixo detalhes sobre o funcionamento das expressões.

Estrutura básica de uma expressão

Identificador

É o nome do campo ou coluna envolvido na expressão, deve ser delimitado por aspas duplas.

  • Exemplos: "Preço médio", "Parafuso 1\" philips", "Vendedor"

Operando de Valor

São os valores numéricos. É possível utilizar tanto valores inteiros quanto valores decimais. Para valores decimais, o separador decimal deverá ser o ponto.

  • Exemplos: 1, 1.05, 2.55
  • Importante: Não é permitido usar separador de milhar nos valores, assim como "," como separador decimal.

Operando de Texto

São os operandos de texto. Para utilizar esse tipo de operando em uma expressão é necessário delimita-los pelo caractere aspa simples (').

  • Exemplos: 'André Moraes', 'São Paulo', 'Espaguete'


Operando de Data

São valores que expressam qualquer data. Para representar uma data nas expressões o comportamento é semelhante aos operandos de texto, ou seja, o conteúdo deve ser circundado por aspa simples ('). Porém deve-se utilizar a máscara dd/MM/aaaa.

  • Exemplos: '01/01/2019', '14/11/2019', '25/12/2019'


Operando Booleano

São operadores do tipo verdadeiro ou falso. Normalmente utilizados para validar, ou não, uma condição em uma expressão mais complexa.

  • Exemplos: true, false


Parênteses

Utilizados para agrupar e separar partes de uma expressão. Expressões dentro de parênteses são processados antes das demais.

  • Exemplos: ("Lucro"/"Preço Total") + 10


Operando de variável do sistema

São variáveis pré-definidas no sistema. Para utilizar as variáveis do sistema deve-se precede-las por hashtag (#) e delimita-las por aspas duplas ("). Atualmente apenas a variável "#null" está disponível e indica conteúdos nulos.

  • Exemplo: IF("Produto" == "#null";0;20)

Expressões Aritméticas

As expressões aritméticas relacionam dois operandos (que pode ser qualquer um dos operandos descritos acima, ou ainda outra expressão) para compor a soma, subtração, multiplicação ou divisão.


Soma (+)

Soma dois operandos de valor. Representado pelo caractere +.

Sintaxe:

 <operando ou expressão> + <operando ou expressão>

Exemplo:

 "Impostos" + "Comissões" – Soma os valores dos campos Impostos e Comissões


Subtração (-)

Subtrai dois operandos de valor ou o resultado de outra expressão. Representado pelo caractere -.

Sintaxe:

 <operando ou expressão> - <operando ou expressão>

Exemplo:

 "Preço" - "Impostos" – Subtrai os valores dos campos Preço e Impostos


Multiplicação (*)

Multiplica dois operandos de valor ou resultados de outra expressão. Representado pelo caractere de multiplicação *.

Sintaxe:

 <operando ou expressão> * <operando ou expressão>

Exemplo:

 "Quantidade" * "Preço Unitário" – Multiplica o valor do campo Quantidade pelo valor do campo Preço Unitário


Divisão (/)

Divide dois operandos de valor ou resultado de outras expressões. Representada pelo caractere de divisão /.

Sintaxe:

 <operando ou expressão> / <operando ou expressão>

Exemplo:

 "Preço" / "Quantidade" – Divide o valor do campo Preço pelo valor do campo Quantidade


Expressões Relacionais

As expressões relacionais comparam dois operandos (valor/texto ou outra expressão) para avaliar se uma condição é verdadeira (true) ou falsa (false). Normalmente utilizada com funções de decisão, como o IF (Se).


Igualdade (==)

Compara se dois operandos são iguais, retornando true se forem iguais ou false se diferentes. Representado pelo operador de igualdade ==.

Sintaxe:

 <operando ou expressão> == <operando ou expressão>

Exemplo:

 IF("Produto" == "#null";0;20) – Se o produto for nulo, considera o valor 0. Caso contrário considera o valor 20


Diferente (!=)

Compara se dois operandos são diferentes, retornando true se foram diferentes ou false se iguais. Representado pelo operador de diferença !=.

Sintaxe:

 <operando ou expressão> != <operando ou expressão>

Exemplo:

 IF("Produto" != 'LASANHA';0;20) – Se o produto for diferente de Lasanha, considera o valor 0. Caso contrário considera o valor 20


Maior que (>)

Compara se o primeiro operador (da esquerda) é maior que o segundo operador (da direita), retornando true se for maior e false se for menor ou igual. Representado pelo operador maior >.

Sintaxe:

 <operando ou expressão> > <operando ou expressão>

Exemplo:

 IF("Valor Bruto" > 1000;1;0) – Se o Valor Bruto for maior que 1000, retorna o valor 1, se não o valor 0


Maior ou igual a (>=)

Compara se o primeiro operador (da esquerda) é maior ou igual ao segundo operador (da direita), retornando true se for maior ou igual e false se for menor. Representado pelo operador maior >=.

Sintaxe:

 <operando ou expressão> >= <operando ou expressão>

Exemplo:

 IF("Valor Bruto" >= 2500;100;0) – Se o Valor Bruto for maior ou igual a 2500 retorna 100, caso contrário retorna 0


Menor que (<)

Compara se o primeiro operador (da esquerda) é menor que o segundo operador (da direita), retornando true se for menor e false se for maior ou igual. Representado pelo operador maior <.

Sintaxe:

 <operando ou expressão> < <operando ou expressão>

Exemplo:

 IF("Valor Bruto" < 100;50;200) – Se o Valor Bruto for menor que 100, retorna 50, se não retorna 200


Menor ou igual a (<=)

Compara se o primeiro operador (da esquerda) é menor ou igual ao segundo operador (da direita), retornando true se for menor ou igual e false se for maior. Representado pelo operador maior <=.

Sintaxe:

 <operando ou expressão> <= <operando ou expressão>

Exemplo:

 IF("Valor Bruto" <= 500;100;0) – Se o Valor Bruto for menor ou igual a 500 retorna 100, se não retorna 0


Expressões Lógicas

As expressões lógicas agrupam dois operandos (booleano ou outra expressão) para compor uma expressão lógica, com o objetivo de avaliar a relação de dois operadores booleanos em um resultado verdadeiro (true) ou falso (false). Normalmente esse tipo de expressão é utilizada para tomadas de decisão, como o IF (Se) e com expressões relacionais.


Operador E (&&)

Executa a operação lógica E entre dois valores booleanos. Ambos os valores devem retornar verdadeiro (true) para que o resultado da operação seja verdadeiro (true). Representado pelo operador &&.

Sintaxe:

 <expressão> && <expressão>

Exemplos:

 IF(("Preço" > 0) && ("Vendedor" == 'André Moraes');450;0) – Se o Preço for maior que 0 E o Vendedor for igual a André Moraes, retorna 450, se não retorna 0
 IF(("Cidade" != "#null") && ("Produto" != 'Lasanha');1;0) – Se a Cidade for diferente de nula E o Produto for diferente de Lasanha retorna 1, se não retorna 0


Operador Ou (||)

Executa a operação lógica OU entre dois valores booleanos. Um dois dois valores deve ser verdadeiro (true) para que o resultado da operação seja verdadeiro (true). Representado pelo operador ||.

Sintaxe:

 <expressão> || <expressão>

Exemplos:

 IF(("Preço" > 1000) || ("Lucro" >= 50);75;55) – Se o Preço for maior que 1000 OU o Lucro for maior ou igual a 50 retorna 75, se não retorna 55
 IF(("Cidade" != "#null") || ("Produto" != 'Lasanha');1;0) - Se Cidade não for null OU Produto deferente de Lasanha returna 1 senão retorna 0


Operador de Negação (!)

Executa a operação lógica de negação para um valor booleano. Se o resultado da operação for verdadeiro (true) o operador de negação converte para falso (false) e vice-versa. Representado pelo operador !.

Sintaxe:

 !<expressão>

Exemplo:

 IF(!BETWEEN("Data Entrega"; '01/01/2015'; '31/12/2015');2016; 2015) – Se a Data Entrega não tiver entre 01/01/2015 e 31/12/2015 retorna 2016. Se estiver entre esse período retorna 2015


Funções Auxiliares

As funções auxiliares básicas são funções padrão do sistema e implementam funcionalidades úteis para compor expressões complexas.


Função ABS

Função que retorna o valor numérico absoluto de um valor numérico base.

Sintaxe:

 ABS(<expressão>)

Exemplo:

 ABS("Preço" / "Quantidade") – Retorna o valor absoluto do Preço divido pela Quantidade


Função AVG

Retorna a média dos valores de uma sequência de valores. Pode ser utilizado para retornar a média de diferentes valores de uma mesma linha das tabelas.

Sintaxe:

 AVG(<expressão 1>; <expressão 2>; ...)

Exemplo:

 AVG("Impostos"; "Lucro"; "Custo") – Retorna a média entre a soma das colunas Impostos, Lucro e Custo


Função BETWEEN (Entre)

Verifica se um valor está estre os limites dos parâmetros utilizados.

Sintaxe:

 BETWEEN(<expressão a ser testada>; <limite inicial>; <limite final>)

Exemplo:

 BETWEEN("Data Emissão"; '01/01/2019'; '31/12/2019') – Retorna true se a Data Emissão estiver entre 01/01/2019 e 31/12/2019. Caso contrário retorna false

Função COUNT

Retorna o número de ocorrências (linhas) de uma coluna ou valor.

Por ora, esta função funciona apenas em expressões de Fontes de Dados

Sintaxe:

 COUNT(<expressão>) 

Exemplo:

 COUNT("Produto") - Retorna o número de ocorrências (linhas) de produtos

Função COUNT_DISTINCT

Retorna o número de ocorrências únicas (linhas) de uma coluna ou valor.

Por ora, esta função funciona apenas em expressões de Fontes de Dados

Sintaxe:

 COUNT_DISTINCT(<expressão>) 

Exemplo:

 COUNT_DISTINCT("Produto") - Retorna o número de ocorrências únicas de produtos

Função IF ELSE (Se.... Senão...)

Testa uma expressão booleana e aplica uma condição em caso verdadeiro (true) ou outra condição nos casos de retornar falso (false). Precisa de três parâmetros, separados por ponto e virgula (;). O primeiro parâmetro é a expressão a ser testada, o segundo o valor a ser aplicado no caso de verdadeiro e o terceiro para ser aplicado no caso de falso.

Sintaxe:

 IF(<expressão a ser testada>; <expressão no caso de verdadeiro>; <expressão no caso de falso>)

Exemplos:

 IF(BETWEEN("Valor"; 0; 100); 10; 250) – Se o Valor estiver entre 0 e 100 retorna 10, se não retorna 250
 IF("Lucro" == 0;0;"Lucro" + "Impostos") - Se Lucro igual a 0 retorna 0, senão retorna a soma de Lucro e Impostos
 IF("Código Produto" == 3231;0;"Quantidade" * 3;"Quantidade") - Se Código Produto igual a 3231 retorna Quantidade vezes 3

Função LOG

Retorna o logaritmo de um número em uma base definida. Pode ser utilizada com apenas um parâmetro, neste caso é utilizado o logaritmo na base 10. Caso seja utilizado dois parâmetros, o segundo serve para informar a base a ser utilizada pelo logaritmo.

Sintaxe:

 LOG(<expressão>; <base>)

Exemplos:

 LOG("Lucro") – Retorna o logaritmo do campo Lucro
 LOG("Preço";2) - Retorna o logaritmo do campo Preço na base 2


Função MAX

Retorna o maior valor entre dois valores.

Sintaxe:

 MAX(<expressão 1>; <expressão 2>)

Exemplo:

 "Valor" / MAX("Quantidade"; 1) – Divide o Valor pelo maior valor entre a Quantidade e 1


Função MIN

Retorna o menor valor entre dois valores.

Sintaxe:

 MIN(<expressão 1>; <expressão 2>)

Exemplo:

 "Valor" / MIN("Custo"; 100) – Divide o Valor pelo menor valor entre Custo e 100


Função POTENCIA

Retorna a potência de um valor em um expoente definido. Pode ser utilizada com apenas um parâmetro, neste caso considera o expoente padrão 2. Se um segundo parâmetro for passado, esse será o expoente.

Sintaxe:

 POW(<expressão>; <expoente>)

Exemplos:

 POW("Lucro") – Retorna a potência do valor Lucro
 POW("Custo"; 3) - Retorna a potência do calor Custo elevado na terceira


Função RANDOM

Retorna um número aleatório dentro dos limites dos valores passados como argumentos.

Sintaxe:

 RANDOM(<limite inicial>; <limite final>)

Exemplo:

 RANDOM(10; 100) – Retorna um número aleatório entre 10 e 100

Função ROUND

Retorna o arredondamento de uma coluna de valor ou valor.

Sintaxe:

 ROUND(<valor>;<precisão>)

Exemplo:

 ROUND("Lucro") - Se lucro for 10.38 retorna 10.00
 ROUND(15.65) - Retorna 16.00
 ROUND(1.777;1) - Retorna 1.8

Função SQRT (Raiz Quadrada)

Retorna a raiz quadrada de um valor.

Sintaxe:

 SQRT(<valor ou expressão>)

Exemplos:

 SQRT("Lucro") – Retorna a raiz quadrada do valor Lucro
 SQRT(81) - Retorna a raiz quadrada de 81


Função LIKE (Contém)

Retorna verdadeiro (true) se o conteúdo desejado for encontrado na lista e falso (false) caso contrário. Precisa de dois parâmetros, o primeiro são os dados que serão consultados e o segundo é o termo a ser encontrado. Lembrando que é necessário utilizar o operador de curinga % e circundar o termo por aspa simples.

Sintaxe:

 LIKE(<dados>; <termo>)

Exemplo:

 LIKE("Produto"; '%anh%') – Retorna true se o Produto contém o termo anh ou false caso contrário
 LIKE("Produto"; '%anh%') - Retorna verdadeiro se o Produto conter a string anh, caso contrário falso

Funções de Data

As funções de data são operações que usam como parâmetro uma data e retornam também uma data. Existem algumas constantes para auxiliar na utilização das funções de data, são elas:

  • 0: DATE_FIELD_YEAR (Parte do ano)
  • 1: DATE_FIELD_MONTH (Parte do mês)
  • 2: DATE_FIELD_DAY (Parte do dia)
  • 3: DATE_FIELD_FORTNIGHT (Parte da quinzena)
  • 5: DATE_FIELD_WEEK (Parte da semana)


Função DATE_PART (Parte da data)

Retorna parte de uma data. Precisa de dois parâmetros, o primeiro é a data de referência e o segundo é a constante que representa qual parte da data queremos obter.

Sintaxe:

 DATE_PART(< data>; <constante que representa qual parte>)

Exemplo:

 DATE_PART("Data Emissão"; 0)  - retorna a parte do ano da Data Emissão


Função DAY_FROM_TODAY (Dias a partir de hoje)

Retorna uma contagem de dias para trás (negativa) ou para frente (positiva) contando a partir de hoje. Precisa de um parâmetro que indica o número de dias para adicionar ou subtrair.

Sintaxe:

 DAY_FROM_TODAY(<número de dias>)

Exemplo:

 DAY_FROM_TODAY(-1) - retorna a data de ontem


Função FIRST_DAY_OF (Primeiro dia de)

Retorna o primeiro dia de um agrupamento. Esta função possui duas variações:

  • Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), e o segundo é a data base.

Sintaxe:

 FIRST_DAY_OF(<parte da data>; < data base>)

Exemplos:

 FIRST_DAY_OF(0; DAY_FROM_TODAY(0)) – retorna o primeiro dia do ano a partir de hoje
 FIRST_DAY_OF(1;"Data Problema") - retorna o primeiro dia baseado na coluna Data Problema
  • Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a primeira data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.

Sintaxe:

 FIRST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)

Exemplo:

 FIRST_DAY_OF(1; 0; -1) – primeiro dia do mês atual do último ano


Função LAST_DAY_OF (Último dia de)

Retorna o último dia de um agrupamento de data. Esta função possui duas variações.

  • Com dois parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), e o segundo é a data base.

Sintaxe:

 LAST_DAY_OF(<parte da data>; < data base>)

Exemplos:

 LAST_DAY_OF(0; DAY_FROM_TODAY(0)) – retorna o último dia do ano a partir de hoje
LAST_DAY_OF(1;"Date Problema") - retorna o último dia do mês baseado na coluna Data Problema
  • Com três parâmetros, o primeiro é a constante do agrupamento da qual queremos obter a última data (vide lista acima), o segundo é o modificador da base da data a partir de hoje e o terceiro é a quantidade para alterar o modificador.

Sintaxe:

 LAST_DAY_OF(<parte da data>; <modificador da data>; <valor modificador da data>)

Exemplo:

 LAST_DAY_OF(1; 0; -1) – último dia do mês atual do último ano


Função NEW_DATE (Nova data)

Cria uma nova data. Precisa de três parâmetros, o primeiro corresponde ao dia (entre 1 e 31), o segundo mês (entre 1 e 12) e o terceiro o ano. A data é criada do ano para o dia, ou seja, o dia deve ser válido para o mês e ano (considerando 29/02, o ano deve ser bissexto).

Sintaxe:

 NEW_DATE(<dia>; <mês>; <ano>)

Exemplo:

 NEW_DATE(1; 4; DATE_PART("Data Emissão"; 0)) – cria o primeiro dia de abril do ano determinado pela linha atual da coluna Data Emissão


Função NUM_OF_DAYS (Número de dias)

Retorna o número de dias entre duas datas. Portanto necessita de duas datas.

Sintaxe:

 NUM_OF_DAYS(< data 1>; < data 2>)

Exemplos:

 NUM_OF_DAYS(FIRST_DAY_OF(0; "Data Emissão"); "Data Emissão") – retorna o número de dias entre o primeiro dia do ano, baseado na coluna Data Emissão, até o dia atual, baseado na mesma coluna
 NUM_OF_DAYS(FIRST_DAY_OF(1;"Data Pedido");LAST_DAY_OF(1;"Data Pedido")) - retorna o número de dias do mês baseado na coluna Data Pedido.


Função NUM_OF_MONTHS (Número de Meses)

Retorna o número de meses entre duas datas. Logo, dois parâmetros data são exigidos.

Sintaxe:

 NUM_OF_MONTHS(< data 1>; < data 2>)

Exemplo:

 NUM_OF_MONTHS(FIRST_DAY_OF(0; "Data"); "Data") – Retorna o número de meses entre o primeiro dia do ano e o mês atual, com base na coluna Data


Função PREVIOUS_DATE (Data anterior)

Dado um dia e um mês, retorna a última ocorrência dessa data. Ou seja, se a data atual (hoje) for menor do que a data passada por parâmetro (dia/mês), o retorno será a data (passada por parâmetro) do ano anterior. Se não o retorno será a data do ano atual.

Sintaxe:

 PREVIOUS_DATE(<dia>; <mês>)

Exemplos:

 PREVIOUS_DATE(15;12) – Considerando que a data de hoje seja 14/11/2019, a última vez que 15/Dezembro ocorreu em relação a data de hoje foi 15/12/2018, logo esse será o retorno.


Variáveis Especiais

Podem ser usadas em conjunto com as expressões para criar cálculos complexos. Devem ser utilizadas entre aspas duplas (")


  • "@count" – Número total de linhas que foram retornadas para o componente
  • "@row" – Número da linha atual
  • "@sum[coluna]" – Somatório da coluna indicada.
    • Exemplo: "@sum[Preço]" – retorna a soma de todas as linhas da coluna Preço
  • "@avg[coluna]" – Média da coluna, semelhante a "@sum[coluna]" / "@count"
  • "@prev[coluna]" – Valor da linha anterior à linha atual, para essa coluna
  • "@totalRowValue[coluna]" - Valor da Linha de Total, (se presente), para essa coluna.
  • "@accumCol[coluna]" – Valor acumulado da coluna até a linha corrente. Útil para calcular média variável.
    • Exemplo: "@accumCol[coluna]" / "@row"