Transformando as linhas em colunas em um Array com PivotTable – Maratona AdvPL e TL++ 386

Nesse vídeo demonstraremos a utilização da função PivotTable, que serve para transformar um array, invertendo as linhas, transformando elas em colunas e as colunas em linhas.

Abaixo o código fonte desenvolvido para o exemplo em vídeo acima:

//Bibliotecas
#Include "TOTVS.ch"

/*/{Protheus.doc} User Function zExe386
Transforma um array tornando linhas em colunas e colunas em linhas
@type Function
@author Atilio
@since 28/03/2023
@obs 
    Função PivotTable
    Parâmetros
        Recebe o array a ser analisado
    Retorno
        Retorna o array convertido com Pivot

    **** Apoie nosso projeto, se inscreva em https://www.youtube.com/TerminalDeInformacao ****
/*/

User Function zExe386()
    Local aArea      := FWGetArea()
    Local aDados     := {}
    Local aDadosNov  := {}

    //Cria um array multidimensional
    aAdd(aDados, {"Daniel", 44, 40, 43})
    aAdd(aDados, {"João",   34, 30, 33})
    aAdd(aDados, {"Maria",  24, 20, 23})
    
    /*
        Agora vai acionar o PivotTable, que irá ficar dessa forma o array:
        [1] - {"Daniel", "João", "Maria"}
        [2] - {44,       34,     24}
        [3] - {40,       30,     20}
        [4] - {43,       33,     23}
    */
    aDadosNov := PivotTable(aDados)

    FWRestArea(aArea)
Return

Bom pessoal, por hoje é só.

Abraços e até a próxima.

Dan (Daniel Atilio)
Cristão de ramificação protestante. Especialista em Engenharia de Software pela FIB, graduado em Banco de Dados pela FATEC Bauru e técnico em informática pelo CTI da Unesp. Entusiasta de soluções Open Source e blogueiro nas horas vagas. Autor e mantenedor do portal Terminal de Informação.

Deixe uma resposta

Terminal de Informação