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 / 1808966
Accepted
Dave
Dave
Asked: 2023-09-19 01:59:34 +0800 CST2023-09-19 01:59:34 +0800 CST 2023-09-19 01:59:34 +0800 CST

Consulta avançada: consulte uma coluna por nome armazenado como um parâmetro de texto (REDUX)

  • 772

Estou usando o Power Query no Excel para Microsoft 365.

A questão que vou colocar é muito semelhante a outra que coloquei recentemente e à qual foi dada uma resposta elegante. Essa pergunta está aqui: Power Query: consulte uma coluna por nome armazenado como um parâmetro de texto

Na questão vinculada acima, precisei filtrar linhas com base na nulidade de uma coluna cuja posição era constante (sempre a primeira coluna) mas cujo nome era difícil de usar porque estava armazenado em um parâmetro de texto. A resposta foi rebaixar os cabeçalhos (dando-lhes nomes previsíveis), filtrar com base na nulidade de Column1 e promover os cabeçalhos (para trazer de volta seus nomes originais). O parâmetro de texto que contém o nome da coluna acabou não entrando em ação.

Na questão atual, preciso novamente filtrar as linhas com base na nulidade de uma coluna cujo nome está armazenado em um parâmetro de texto, mas desta vez nem sempre será a primeira coluna. Pode ser a primeira, segunda, terceira ou quarta coluna. Então, desta vez, eu realmente preciso usar o parâmetro que especifica o nome da coluna.

Apresentarei novamente minha pergunta original, alterada para refletir esse novo requisito.

Aqui está minha tabela de dados de origem (cujo nome da tabela é Source ):

Col1 Col2 Col3 Col4 Nome
11 21 31 41 Cachorro
12 22 32 42 Gato
23 33 43 Avestruz
14 24 44 Periquito
15 25 35 45 Truta

Eu defini um parâmetro de texto:

  • FilterColumnespecifica o nome da coluna que será usada para filtrar valores nulos . Pode assumir qualquer um dos valores Col1 , Col2 , Col3 ou Col4 .

Meu objetivo é desenvolver um Power Query para filtrar linhas onde há um nulo na coluna especificada por FilterColumn.

Supondo que eu configurei FilterColumnCol3 , o resultado desejado é:

Col1 Col2 Col3 Col4 Nome
11 21 31 41 Cachorro
12 22 32 42 Gato
23 33 43 Avestruz
15 25 35 45 Truta

Aqui está o código da linguagem M para minha consulta do Power:

let
    Source = Excel.CurrentWorkbook(){[Name="Source"]}[Content],
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Col1", Int64.Type}, {"Col2", Int64.Type}, {"Col3", Int64.Type}, {"Col4", Int64.Type}, {"Name", Text.Type}}),
    // #"Filtered Rows" = Table.SelectRows(#"Changed Type", each [FilterColumn] <> null and [FilterColumn] <> "")
    // #"Filtered Rows" = Table.SelectRows(#"Changed Type", each FilterColumn <> null and FilterColumn <> "")
in
    #"Filtered Rows"

É a etapa aplicada #"Filtered Rows" que está dando errado. No código acima, mostro duas tentativas (comentadas) que fiz de implementar esta etapa aplicada.

Na primeira tentativa, simplesmente me refiro diretamente ao nome da coluna (entre colchetes). No entanto, FilterColumné considerado o nome da coluna de interesse, e não como um parâmetro de texto que contém o nome da coluna. Um erro é gerado porque não há coluna chamada FilterColumn :Expression.Error: The field 'FilterColumn' of the record wasn't found.

Na segunda tentativa, novamente me refiro diretamente ao nome da coluna, mas desta vez sem colchetes. Isso não gera um erro, mas nenhuma linha é filtrada. A saída permanece inalterada em relação à entrada.

Como posso filtrar linhas com base em valores nulos em uma coluna nomeada pelo parâmetro FilterColumn?

microsoft-excel
  • 2 2 respostas
  • 41 Views

2 respostas

  • Voted
  1. Best Answer
    Ron Rosenfeld
    2023-09-19T03:29:25+08:002023-09-19T03:29:25+08:00

    Você precisa passar o parâmetro como uma string de texto, então tente:

    #"Filtered Rows" = Table.SelectRows(#"Changed Type", (r)=>Record.Field(r,FilterColumn)<>null)
    

    ou

    #"Filtered Rows" = Table.SelectRows(#"Changed Type", 
            each Record.Field(_,FilterColumn) <> null 
            and Record.Field(_,FilterColumn) <> "")
    
    • 1
  2. Rajesh Sinha
    2023-09-19T12:50:57+08:002023-09-19T12:50:57+08:00

    Você pode usar isso também,,,

    #"Filtered Rows" = Table.SelectColumns(Table.SelectRows(#"Changed Type", each [FilterColumn] <> null and [FilterColumn] <> ""), {"Column1", "Column2", ...})
    

    Observação

    Nesta abordagem.

    1. Table.SelectRows(...)usado para filtrar linhas com base na condição especificada e Table.SelectColumns(...)usado para selecionar as colunas desejadas nas linhas filtradas.
    2. Substitua Coluna1, Coluna2, pelos nomes reais das colunas.

    Essa abordagem combina a filtragem da seleção de linhas e colunas em uma única etapa, o que pode ser mais eficiente e tornar o código mais conciso.

    • 0

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
    Vickel O Firefox não permite mais colar no WhatsApp web? 2023-08-18 05:04:35 +0800 CST
  • 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
    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