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 / 1641391
Accepted
ExcelEverything
ExcelEverything
Asked: 2021-04-13 16:21:28 +0800 CST2021-04-13 16:21:28 +0800 CST 2021-04-13 16:21:28 +0800 CST

DESAFIO: Fórmula não volátil para referenciar dinamicamente qualquer célula em qualquer planilha

  • 772

Como você faz referência dinamicamente a qualquer célula com base em um nome de planilha variável ou número e seleção de número de linha e coluna (digamos, por meio de uma lista suspensa)?

Eu sei que INDIRETO seria a abordagem padrão (detalhada abaixo), mas como o INDIRETO é volátil (recalcula para cada pequena alteração na pasta de trabalho), pode diminuir consideravelmente sua planilha. Isso pode ser feito usando meios não voláteis? Também sei que as referências 3D podem ser úteis em casos selecionados em que você está, por exemplo, somando ou calculando a média em várias planilhas, mas não funcionará para endereçamento de célula individual.

Também vou propor minhas próprias respostas para essa pergunta usando INDEX(CHOOSE(...)), mas talvez haja uma maneira melhor?

microsoft-excel
  • 1 1 respostas
  • 264 Views

1 respostas

  • Voted
  1. Best Answer
    ExcelEverything
    2021-04-13T16:21:28+08:002021-04-13T16:21:28+08:00

    Primeiro, a maneira fácil/usual/volátil de endereçar dinamicamente qualquer célula em qualquer planilha

    Digamos que o nome da planilha necessário esteja em A1 ="JAN" e os números de linha e coluna estejam em B1 = 1 e C1 = 1, então:

    =INDIRECT(ADDRESS(B1, C1,,,A1))
    

    retornaria a referência/valor em JAN!$A$1. Você também pode retornar um intervalo inteiro assim:

    =SUM(INDIRECT(ADDRESS(B1, C1,,,A1)&":"&ADDRESS(9,C1)))
    

    Que retornaria o valor de SUM(JAN!$A$1:$A$9)

    Agora, para um método não volátil

    Você pode usar a seguinte fórmula não volátil para indexar em qualquer célula em qualquer planilha, desde que a lista de planilhas seja estática/ou possa ser atualizada manualmente conforme necessário. A função CHOOSE pode retornar uma referência a cada planilha na pasta de trabalho com base no número de índice fornecido para CHOOSE. Você precisa usar CHOOSE com INDEX, pois INDEX não funciona normalmente em várias planilhas.

    =INDEX(CHOOSE(*sheetnumber*,Sheet1!$A:$ZFD,Sheet2!$A:$ZFD,Sheet3!$A:$ZFD),*row number*,*column number*). 
    

    Você deve estender essa fórmula manualmente para incluir todas as planilhas da sua pasta de trabalho. A ordem em que você os coloca na lista de funções CHOOSE determina a ordem do número da planilha do índice CHOOSE (não a ordem na qual as planilhas são classificadas na pasta de trabalho).

    Se seria preferível definir a longa função INDEX(CHOOSE(...)) como uma célula ou intervalo nomeado, para que você não precise digitá-la em várias fórmulas de célula (e se você tiver que editá-la/adicionar uma nova planilha, você só precisa editar o nome definido uma vez). Você pode usar nomes de definição relativos para adicionar as variáveis ​​para números de planilha, linha e coluna ao intervalo nomeado em células adjacentes ou, no Office 365, defina o nome diga SHEETINDEX usando a função lambda =LAMBDA(sheetnum, r, c, INDEX(CHOOSE(sheetnum,Sheet1!$A:$ZFD,Sheet2!$A:$ZFD,Sheet3!$A:$ZFD),r,c). Dessa forma, você pode usar o intervalo nomeado como uma função =SHEETINDEX(1,1,1)para retornar Sheet1!$A$1.

    • 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
    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