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 / 1837817
Accepted
LWC
LWC
Asked: 2024-04-04 16:30:33 +0800 CST2024-04-04 16:30:33 +0800 CST 2024-04-04 16:30:33 +0800 CST

Uma função de filtro do Excel pode basear sua inclusão em uma linha inteira?

  • 772

Eu tenho uma tabela da qual extraio uma lista de valores exclusivos, depois quero extrair todas as suas chaves e mesclá-las usando textjoin. Mas a função Filter faz com que os critérios sejam comparados com um único valor, enquanto eu quero que os critérios procurem uma linha inteira.

Em circunstâncias normais, eu ficaria com um único valor e deixaria arrastar a cidade com uma tabela, mas neste caso a fonte é uma função Única, portanto não pode ser uma tabela.

Agora é:

A1:B6 is a Table called Table1
D1=UNIQUE(Table1[[#All],[Item]])
E2=TEXTJOIN($E$1, TRUE, FILTER(Table1[Key],Table1[Item]=D2))
E3=TEXTJOIN($E$1, TRUE, FILTER(Table1[Key],Table1[Item]=D3))
E4=TEXTJOIN($E$1, TRUE, FILTER(Table1[Key],Table1[Item]=D4))

Mas os dados são dinâmicos, então não posso continuar fazendo D5, D6, etc. e também não quero apenas arrastar para baixo as células não utilizadas porque isso torna o arquivo mais lento.

Então, o que estou procurando é algo como E2 =TEXTJOIN($E$1, TRUE, FILTER(Table1[Key],Table1[Item]= D:D )) mais apenas para células D não vazias, então o resultado será sem precisar colocar fórmulas em E3, E4, etc.:

A B C D E
1 Item Chave Item ,
2 foo dfgsd foo dfgsd,6456hfghd
3 bar gdfghsh bar gdfghsh,fuibdgdb
4 foo 6456hfghd algo dsfkgjlcb
5 algo dsfkgjlcb
6 bar fuibdgdb

É possível? Consulte uma pergunta semelhante específica do Planilhas Google .

Além disso, e se houver várias chaves, ou seja E2=TEXTJOIN($E$1, TRUE, FILTER(Table2[Key1] & $F$1 & Table2[Key2], Table1[Item]=D2))?

A B C D E F
1 Item Chave1 Chave2 Item , -
2 foo dfgsd 1ab foo dfgsd - 1ab,6456hfghd - 3dfv
3 bar gdfghsh sdfg bar gdfghsh - sdfg,fuibdgdb - h3vf
4 foo 6456hfghd 3dfv algo dsfkgjlcb-fskib
5 algo dsfkgjlcb fskib
6 bar fuibdgdb h3vf
microsoft-excel
  • 2 2 respostas
  • 44 Views

2 respostas

  • Voted
  1. Mayukh Bhattacharya
    2024-04-04T16:37:33+08:002024-04-04T16:37:33+08:00

    Aqui está o que você pode fazer usando BYROW()o qual aplica cálculos personalizados LAMBDA()a cada linha na matriz de xpara verificar se cada valor xé igual a Table1[Item]retornar uma lista delimitada, uma saída por linha com o respectivo Table1[Key].

    insira a descrição da imagem aqui


    =BYROW(D1#,LAMBDA(x, TEXTJOIN(", ",1,FILTER(Table1[Key],Table1[Item]=x,","))))
    

    Ou, usandoMAP()

    =VSTACK(",",DROP(MAP(D1#,LAMBDA(x,TEXTJOIN(", ",1,IF(x=Table1[Item],Table1[Key],"")))),1))
    

    Esta é apenas uma alternativa, não necessária como BYROW()deveria, o que você está tentando alcançar, aqui está usando MAP()a função:

    =LET(
         _LastRow, MATCH(2,1/(D:D<>"")),
         VSTACK(", ",MAP(D2:INDEX(D:D,_LastRow), LAMBDA(x,
         TEXTJOIN(", ",1,IF(Table1[Item]=x,Table1[Key],""))))))
    

    • 1
  2. Best Answer
    LWC
    2024-04-05T03:00:46+08:002024-04-05T03:00:46+08:00

    Aqui está uma alternativa do Power Query para quem não tem 365 (que pode usar isso )?

    1. Escolha sua tabela original e Data=>From Table/Range (em Get & Transform Data )
    2. Clique com o botão direito na última etapa e escolha Inserir etapa após
    3. Substitua a fórmula na parte superior por (e renomeie Previous Step Name ):
      • Se você tiver apenas 1 coluna-chave, então:= Table.Group(#"Previous Step Name", {"Item"}, {{"CombinedKeys", each Text.Combine(List.Distinct(List.Transform(Table.Column(_, "Key"), Text.From)), ","), type text}})
      • Se você tiver várias colunas-chave, então:= Table.Group(#"Previous Step Name", {"Item"}, {{"CombinedKeys", each Text.Combine(List.Distinct(List.Transform(Table.ToRecords(_), each Text.From([Key1]) & " - " & Text.From([Key2]))), ","), type text}})
    4. Saia do Power Query e escolha Manter

    PS Se você quiser filtrar certas chaves, como 0 e -1, veja como:

    = Table.Group(#"Previous Step Name", {"Item"}, {{"CombinedKeys", each Text.Combine(
        let
            currentRecords = Table.ToRecords(_),
            nonZeroNonNegativeOneRecords = List.Select(currentRecords, each Text.From([Key1]) <> "0" and Text.From([Key1]) <> "-1"),
            zeroOrNegativeOneRecords = List.Select(currentRecords, each Text.From([Key1]) = "0" or Text.From([Key1]) = "-1"),
            validZeroOrNegativeOneRecords = List.Select(zeroOrNegativeOneRecords, each List.IsEmpty(List.Select(nonZeroNonNegativeOneRecords, (nr) => nr[Item] = _[Item]))),
            combinedRecords = List.Combine({nonZeroNonNegativeOneRecords, validZeroOrNegativeOneRecords}),
            combinedTexts = List.Distinct(List.Transform(combinedRecords, each Text.From([Key1]) & " - " & [Key2]))
        in
            combinedTexts, ","), type text}})
    
    • 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