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 / 1691191
Accepted
bat_cmd
bat_cmd
Asked: 2021-12-05 01:21:54 +0800 CST2021-12-05 01:21:54 +0800 CST 2021-12-05 01:21:54 +0800 CST

Encurtar a fórmula "SE" do Excel?

  • 772

Esta fórmula funciona, mas é enorme:

=IF(X3=B2,K2,IF(X3=B3,K3,IF(X3=B4,K4,IF(X3=B5,K5,IF(X3=B6,K6,IF(X3=B7,K7,IF(X3=B8,K8,IF(X3=B9,K9,IF(X3=B10,K10,IF(X3=B11,K11,IF(X3=B12,K12,IF(X3=B13,K13,IF(X3=B14,K14,IF(X3=B15,K15,IF(X3=B16,K16,IF(X3=B17,K17,IF(X3=B18,K18,IF(X3=B19,K19,IF(X3=B20,K20,IF(X3=B21,K21))))))))))))))))))))

Aqui está o que está fazendo:

If X3 is the same as B2, show the contents of cell K2.
If X3 is the same as B3, show the contents of cell K3.
If X3 is the same as B4, show the contents of cell K4.
...etc etc etc all the way to...
If X3 is the same as B21, show the contents of cell K21.

Como B2:B21 é simplesmente uma coluna de células e K2:K21 também é apenas uma coluna de células, existe alguma maneira de encurtar a fórmula acima, para que não seja enorme?

Eu não sei como transformar isso em 2 intervalos de células B e células K.

Tentar algo assim não funciona: =IF(X3=B2:B21,K2:K21)

Porque dizer ao Excel para usar :é dizer para somar tudo, de B2 a B21 e K2 a K21. Gostaria de saber se há algum outro separador (não um :) que diz ao Excel para tratar cada célula individualmente em vez de adicioná-las?

Isso não funciona: =IF(X3=B2-B21,K2-K21)

Isso resulta em:#VALUE!

O problema é que, qualquer que seja o número da célula B, também deve ser correspondido com o número correspondente (horizontalmente) na célula K.

Obrigado antecipadamente a qualquer um que possa saber a resposta, que tenho certeza que é realmente simples se a funcionalidade existir no Excel.

microsoft-excel worksheet-function
  • 3 3 respostas
  • 562 Views

3 respostas

  • Voted
  1. Best Answer
    FlexYourData
    2021-12-05T05:26:21+08:002021-12-05T05:26:21+08:00

    Dependendo da sua versão do Excel, você pode usar XLOOKUP, VLOOKUPouINDEX/MATCH

    insira a descrição da imagem aqui

    =XLOOKUP($X$3,$B$2:$B$22,$K$2:$K$22,"")
    =VLOOKUP($X$3,$B$2:$K$22,10,FALSE)
    =INDEX($K$2:$K$22,MATCH($X$3,$B$2:$B$22))
    
    • 7
  2. Hannu
    2021-12-05T02:31:47+08:002021-12-05T02:31:47+08:00

    =VLOOKUP(X3;B2:K21;columns(B2:K2))

    • Procure o valor de X3̈́ entre B2:B21, (primeira coluna do intervalo)
    • quando encontrado, selecione e exiba o valor B2:K2-colunas à direita.

    ... e Sim PROCV leva mais um argumento, que normalmente é revelado quando você digita o nome da função, ou mesmo quando você pressiona F1 (Ajuda).
    O valor padrão desse argumento é True, portanto, não é necessário digitá-lo nesse caso, mas se você precisar de correspondência exata no primeiro argumento, será necessário dizer 'False' aqui.

    Adicione IFERROR(...;"Not found")ao redor para exibir sua indicação de "nada encontrado".

    --- arquivo: exemplo.csv --- M4 usado em vez de X3 acima

    ,,,,,,,,,,,,
    ,1,,,,,,,,,A,,
    ,2,,,,,,,,,B,,"=PROCV(M4;B2:K21;10;Falso)"
    ,3,,,,,,,,,C,,5
    ,4,,,,,,,,,D,,
    ,5,,,,,,,,,E,,
    ,6,,,,,,,,,F,,
    ,7,,,,,,,,,G,,
    ,8,,,,,,,,,H,,
    ,9,,,,,,,,,eu,,
    ,10,,,,,,,,,J,,
    ,11,,,,,,,,,K,,
    ,12,,,,,,,,,L,,
    ,13,,,,,,,,,M,,
    ,14,,,,,,,,,N,,
    ,15,,,,,,,,,O,,
    ,16,,,,,,,,,P,,
    ,17,,,,,,,,,Q,,
    ,18,,,,,,,,,R,,
    ,19,,,,,,,,,S,,
    ,20,,,,,,,,,T,,
    ,21,,,,,,,,,U,,

    • 2
  3. Ilmari Karonen
    2021-12-05T12:14:25+08:002021-12-05T12:14:25+08:00

    No mínimo, podemos nos livrar dos parênteses extras usando IFS:

    =IFS(X3=B2,K2,X3=B3,K3,X3=B4,K4,X3=B5,K5,X3=B6,K6,X3=B7,K7,X3=B8,K8,X3=B9,K9,X3=B10,K10,X3=B11,K11,X3=B12,K12,X3=B13,K13,X3=B14,K14,X3=B15,K15,X3=B16,K16,X3=B17,K17,X3=B18,K18,X3=B19,K19,X3=B20,K20,X3=B21,K21)

    Esta é uma simplificação geral que funciona sempre que você tem funções aninhadas IFcomo essa, mesmo que as diferentes condições e resultados não tenham nada em comum.

    No entanto, no seu caso, há um padrão simples para as condições e podemos simplificar ainda mais sua expressão, por exemplo, usando using XLOOKUP:

    =XLOOKUP(X3, B2:B21, K2:K21)

    Observe que XLOOKUPé um novo recurso do Excel 2021 e pode não funcionar em versões mais antigas do Excel. Para essas versões, você pode obter o mesmo resultado usando INDEXe MATCH, como em:

    =INDEX(K2:K21, MATCH(X3, B2:B21, 0))

    ou usando VLOOKUP:

    =VLOOKUP(X3, B2:K21, COLUMNS(B2:K2), FALSE)

    Onde suportado, no entanto, XLOOKUPé provavelmente a solução mais conveniente neste caso, e também suporta vários parâmetros adicionais que permitem especificar como a pesquisa é feita e o que fazer caso nenhuma correspondência exata seja encontrada.

    (Observe também que as soluções INDEX/ MATCHe VLOOKUPterão de ser ajustadas, ou podem não funcionar, se você quiser, por exemplo, pesquisar ao longo de uma linha em vez de uma coluna ou retornar um valor de uma coluna que está à esquerda da pesquisa deve funcionar em todos os casos, o que IMO é uma boa razão para preferi-lo sempre que possível. XLOOKUP)

    • 1

relate perguntas

  • 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