match – função de script e gráfico
A função match compara o primeiro parâmetro com todos os seguintes e retorna a localização numérica das expressões correspondentes. A comparação faz distinção de maiúsculas e minúsculas.
Sintaxe:
match( str, expr1 [ , expr2,...exprN ])
Alguns dos exemplos neste tópico usam carregamentos inline. Para obter mais informações, consulte Carregamentos inline.
Exemplo: Script de carregamento usando match
Script de carregamento
Você pode usar match para carregar um subconjunto de dados. Por exemplo, você pode retornar um valor numérico para uma expressão na função. Em seguida, é possível limitar os dados carregados com base no valor numérico. Match retornará 0 se não houver correspondência. Portanto, todas as expressões não correspondidas neste exemplo retornarão 0 e serão excluídas do carregamento de dados pelo comando WHERE.
Crie uma nova guia no editor de carregamento de dados e carregue os dados a seguir como um carregamento inline. Crie a tabela abaixo no Qlik Sense para ver os resultados.
Transactions: Load * Inline [ transaction_id, transaction_date, transaction_amount, transaction_quantity, customer_id, size, color_code 3750, 20180830, 23.56, 2, 2038593, L, Red 3751, 20180907, 556.31, 6, 203521, m, orange 3752, 20180916, 5.75, 1, 5646471, S, blue 3753, 20180922, 125.00, 7, 3036491, l, Black 3754, 20180922, 484.21, 13, 049681, xs, Red 3756, 20180922, 59.18, 2, 2038593, M, Blue 3757, 20180923, 177.42, 21, 203521, XL, Black ]; /* Create new table called Transaction_Buckets Create new fields called Customer, and Color code - Blue and Black Load Transactions table. Match returns 1 for 'Blue', 2 for 'Black'. Does not return a value for 'blue' because match is case sensitive. Only values that returned numeric value greater than 0 are loaded by WHERE statment into Transactions_Buckets table. */ Transaction_Buckets: Load customer_id, customer_id as [Customer], color_code as [Color Code Blue and Black] Resident Transactions Where match(color_code,'Blue','Black') > 0;
Resultados
Color Code Blue and Black | Customer |
---|---|
Black | 203521 |
Black | 3036491 |
Blue | 2038593 |
Exemplos - Expressões de gráfico usando match
Expressão de gráfico 1
Script de carregamento
Crie uma nova guia no editor de carregamento de dados e carregue os dados a seguir como um carregamento inline. Depois de carregar os dados, crie os exemplos de expressão de gráfico abaixo em uma tabela do Qlik Sense.
MyTable: Load * inline [Cities, Count Toronto, 123 Toronto, 234 Toronto, 231 Boston, 32 Boston, 23 Boston, 1341 Beijing, 234 Beijing, 45 Beijing, 235 Stockholm, 938 Stockholm, 39 Stockholm, 189 zurich, 2342 zurich, 9033 zurich, 0039];
A primeira expressão da tabela a seguir retorna 0 para Stockholm, porque "Stockholm" não está incluído na lista de expressões da função match. Também retorna 0 para "Zurich", porque a comparação match diferencia maiúsculas de minúsculas.
Cities | match( Cities,'Toronto','Boston','Beijing','Zurich') | match( Cities,'Toronto','Boston','Beijing','Stockholm','zurich') |
---|---|---|
Beijing |
3 |
3 |
Boston | 2 | 2 |
Stockholm | 0 | 4 |
Toronto | 1 | 1 |
zurich | 0 | 5 |
Expressão de gráfico 2
Você pode usar match para realizar uma classificação personalizada para uma expressão.
Por padrão, as colunas são classificadas numérica ou alfabeticamente, dependendo dos dados.
Cities |
---|
Beijing |
Boston |
Stockholm |
Toronto |
zurich |
Para alterar a ordem, faça o seguinte:
- Abra a seção Classificação do gráfico no painel Propriedades.
- Desative a classificação automática para a coluna na qual você deseja fazer uma classificação personalizada.
- Desmarque Classificar numericamente e Classificar alfabeticamente.
-
Selecione Classificar por expressão e insira uma expressão semelhante à seguinte:
=match( Cities, 'Toronto','Boston','Beijing','Stockholm','zurich')
A ordem de classificação na coluna Cities é alterada.
Cities |
---|
Toronto |
Boston |
Beijing |
Stockholm |
zurich |
Você também pode exibir o valor numérico retornado.
Cidades | Cities & ' - ' & match ( Cities, 'Toronto','Boston', 'Beijing','Stockholm','zurich') |
---|---|
Toronto | Toronto - 1 |
Boston | Boston - 2 |
Beijing | Beijing - 3 |
Stockholm | Stockholm - 4 |
zurich | zurich - 5 |