AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1689105
Accepted
Lluser
Lluser
Asked: 2021-11-24 06:30:04 +0800 CST2021-11-24 06:30:04 +0800 CST 2021-11-24 06:30:04 +0800 CST

Excel: Power Query - como repetir o bloco de código para cada linha em uma tabela

  • 772

Eu tenho JSON no formato assim:

{
  "data": [
    {
      "date": "2021-01-01",
      "data": 10
    },
    {
      "date": "2021-01-02",
      "data": 20
    },
    {
      "date": "2021-01-03",
      "data": 30
    }
  ]
}

Eu sou capaz de escrever este código que faz exatamente o que eu quero:

let
    Source = Json.Document(...),
    data = Source[data],
    #"ToTable" = Table.FromList(data, Splitter.SplitByNothing(), null, null, ExtraValues.Error),
    
// Block 1 Start
    Column1 = #"ToTable"{0}[Column1], //Gets Record from 1st "data" Array item
    #"ToTable1" = Record.ToTable(Column1), //Create table with two columns (key, value)
    #"Transpose1" = Table.Transpose(#"ToTable1"), //Transpose the table
    #"Headers1" = Table.PromoteHeaders(#"Transpose1", [PromoteAllScalars=true]), //Get headers from the 1st row (key names)
    #"ChangeType1" = Table.TransformColumnTypes(#"Headers1",{{"date", type date}, {"value", Int64.Type}, type any}}), //Change Type
// Block 1 End

// Block 2 Start
    Column2 = #"ToTable"{1}[Column1], //Gets Record from 2nd "data" Array item
    #"ToTable2" = Record.ToTable(Column2),
    #"Transpose2" = Table.Transpose(#"ToTable2"),
    #"Headers2" = Table.PromoteHeaders(#"Transpose2", [PromoteAllScalars=true]),
    #"ChangeType2" = Table.TransformColumnTypes(#"Headers2",{{"date", type date}, {"value", Int64.Type}, type any}}),
// Block 2 End

// Block 3 Start
    Column3 = #"ToTable"{2}[Column1], //Gets Record from 3rd "data" Array item
    #"ToTable3" = Record.ToTable(Column3),
    #"Transpose3" = Table.Transpose(#"ToTable3"),
    #"Headers3" = Table.PromoteHeaders(#"Transpose3", [PromoteAllScalars=true]),
    #"ChangeType3" = Table.TransformColumnTypes(#"Headers3",{{"date", type date}, {"value", Int64.Type}, type any}}),
// Block 3 End

    TheTable = Table.Combine({ChangeType1, ChangeType2, ChangeType3}) //Combines tables together
in
    TheTable

MAS

Isso tudo está OK para 3 itens no Array "data", não quando existem centenas deles.

Existe algum truque como repetir Code blockpara cada linha em data[Column1], obter um Listde Tabelas (ChangeTypeX) para usar em Table.Combine?

microsoft-excel power-query
  • 2 2 respostas
  • 776 Views

2 respostas

  • Voted
  1. Lluser
    2021-11-24T07:53:37+08:002021-11-24T07:53:37+08:00

    Vamos começar do começo

    let
        Source = Json.Document(...),
        data = Source[data],
        #"ToTable1" = Record.ToTable(Column1)
    

    Agora temos Listde Records armazenados em #"ToTable1"[Column1]. (Porque as colunas da tabela são Lists.)

    Assim, podemos usar a List.Transformfunção para manipular com cada Itemum List.

    A sintaxe é

    List.Transform(list as list, transform as function) as list
    

    Portanto, precisamos de alguma função de transformação que funcione com cada item da lista separadamente. Vamos modificar um bloco de código da pergunta original.

    MyFunc = (ColumnRow) =>
    let
      #"ToTableX" = Record.ToTable(ColumnRow),
      #"TransposeX" = Table.Transpose(#"ToTableX"),
      #"HeadersX" = Table.PromoteHeaders(#"TransposeX", [PromoteAllScalars=true]),
      #"ChangeTypeX" = Table.TransformColumnTypes(#"HeadersX",{{"date", type date}, {"value", Int64.Type}, type any}})
    in
    
    #"ChangeTypeX"
    

    Assim, todo o List.Tranformcódigo de função se parece com

    List.Transform(#"ToTable1"[Column1], MyFunc)
    

    Isso retorna um Listde Tables que pode ser usado em Table.Combinefunction .

    MyResultTable = Table.Combine(List.Transform(#"ToTable1"[Column1], MyFunc))
    

    Coloque tudo junto

    let
      Source = Json.Document(...),
      data = Source[data],
      #"ToTable1" = Record.ToTable(Column1)
    // End of original code used here
      
      MyList = #"ToTable1"[Column1], //For better readability
      MyFunc = (ColumnRow) =>
      let
        #"ToTableX" = Record.ToTable(ColumnRow),
        #"TransposeX" = Table.Transpose(#"ToTableX"),
        #"HeadersX" = Table.PromoteHeaders(#"TransposeX", [PromoteAllScalars=true]),
        #"ChangeTypeX" = Table.TransformColumnTypes(#"HeadersX",{{"date", type date}, {"value", Int64.Type}, type any}})
      in
      
      #"ChangeTypeX",
      
      MyResultTable = Table.Combine(List.Transform(MyList, MyFunc))
       
      in
      
      MyResultTable 
    
    • 2
  2. Best Answer
    Ron Rosenfeld
    2021-11-25T02:14:47+08:002021-11-25T02:14:47+08:00

    Parece que você deseja ter um resultado com duas colunas datee data. Se for esse o caso, tudo o que você precisa fazer é expandir a tabela resultante da Etapa 3.

    Basta clicar na seta de duas pontas na parte superior da coluna

    insira a descrição da imagem aqui

    Código M

    let
        Source = Json.Document(File.Contents("C:\Users\ron\Desktop\new 3.json")),
        data = Source[data],
        #"Converted to Table" = Table.FromList(data, Splitter.SplitByNothing(), null, null, ExtraValues.Error),
        #"Expanded Column1" = Table.ExpandRecordColumn(#"Converted to Table", "Column1", {"date", "data"}, {"date", "data"})
    in
        #"Expanded Column1"
    

    Resultado
    insira a descrição da imagem aqui

    Você também deve definir os tipos de dados depois de expandir as colunas

    • 1

relate perguntas

  • Excel Pivot com operador "e"

  • Como usar a função LENGTH do Excel para uma coluna inteira?

  • Matriz do Excel (2 variáveis)

  • como abrir um arquivo de escritório do WSL

  • VBA para renomear planilha com base no nome do arquivo

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    Saaru Lindestøkke Por que os arquivos tar.xz são 15x menores ao usar a biblioteca tar do Python em comparação com o tar do macOS? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve