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 / 1892617
Accepted
Jake Nixon
Jake Nixon
Asked: 2025-04-18 02:13:05 +0800 CST2025-04-18 02:13:05 +0800 CST 2025-04-18 02:13:05 +0800 CST

Como posso escrever uma fórmula do Excel que executa várias passagens de xlookup em que cada passagem se refere ao valor máximo retornado da passagem anterior?

  • 772

Tenho duas tabelas do Excel chamadas FacilityLoss e MappingTable. A tabela FacilityLoss tem duas colunas, FiberNum e Loss. FiberNum tem linhas com valores de 1 a 30, e Loss contém os valores de perda de fibra registrados para cada fibra numerada.

Tenho uma célula chamada "Tolerância" que especifica um valor máximo de perda permitido.

A MappingTable possui duas colunas, Fibra UUT e Fibra da Instalação. A coluna UUT possui linhas com valores de 1 a 20. A coluna Fibra da Instalação precisa ser preenchida com fibras da instalação que apresentem valores de perda inferiores ao valor de tolerância. Queremos priorizar conexões 1:1 entre fibras UUT e fibras da instalação para melhorar a clareza da configuração.

Atualmente, tenho a seguinte fórmula nas células da coluna Fibra da Instalação:

=IF(XLOOKUP([@[UUT Fiber]],FacilityLoss[Fiber Num],FacilityLoss[Loss])<=Tolerance,[@[UUT Fiber]],"")

Como você pode ver, funciona corretamente para fibras boas, mas preciso que ele retome a contagem começando pela próxima fibra mais alta em uma segunda passagem.

Captura de tela do Excel com duas tabelas, MappingTable e FacilityLoss

Não preciso que seja infinitamente recursivo; algumas passagens já seriam suficientes. Tentei criar uma coluna auxiliar que preencheria valores em branco com números que aumentam em um, apesar de pular várias linhas, mas não consigo fazer funcionar direito.

Também implementei uma fórmula para a célula de Tolerância que calcula a melhor tolerância com base no número de fibras solicitadas:

=SMALL(FacilityLoss[Loss],MAX(MappingTable[UUT Fiber]))

Como posso modificar a fórmula XLOOKUP() na coluna FacilityFiber da MappingTable para que ela faça o que eu quero? Aqui está uma captura de tela dos valores corretos preenchidos manualmente:

MappingTable corrigido manualmente

Estou usando o Microsoft Excel para Microsoft 365 MSO (versão 2502 build 16.0.18526.20286) de 64 bits.

microsoft-excel
  • 2 2 respostas
  • 69 Views

2 respostas

  • Voted
  1. Best Answer
    MGonet
    2025-04-18T08:41:53+08:002025-04-18T08:41:53+08:00

    De acordo com a ideia de solução apresentada, a seguinte fórmula pode ser utilizada:

    =IF(XLOOKUP([@[UUT Fiber]], FacilityLoss[Fiber Num], FacilityLoss[Loss])<=Tolerance, [@[UUT Fiber]], 
    MIN(IF((FacilityLoss[Loss]<=Tolerance)*(FacilityLoss[Fiber Num]>MAX(ROWS(MappingTable), 
    MappingTable[[#Headers], [Facility Fiber]]:OFFSET([@[Facility Fiber]],-1,0))), FacilityLoss[Fiber Num])))  
    

    Fibras

    • 2
  2. gns100
    2025-04-19T02:52:45+08:002025-04-19T02:52:45+08:00

    Isso é quase um desafio de quadro e não usa Xlookup. Se entendi as restrições corretamente, aqui está uma solução alternativa:

    =IF(E3<=$G$3,D3,INDEX(FILTER($D$23:$D$32,$E$23:$E$32<=$G$3),COUNTIF($E$3:E3,">"&$G$3)))

    Isso seria colado na célula B3 e depois copiado/colado na célula B22

    decompondo isso

    • a thenpeça atribui o número da fibra (1-20) à instalação correspondente ifdentro da tolerância
    • A elseparte atribui o número de fibras (21-30) à instalação iffora da tolerância. O truque nesta parte é criar uma matriz de números de fibras que atendam à tolerância usando o método " filterentão index" e, em seguida, percorrer essa matriz com base na posição do subconjunto de itens em 1-20 que excedem a tolerância usando o método " countife ancorar parcialmente a matriz para contar".

    A suposição é que a tolerância será ajustada (talvez com o solucionador) para obter os 20 "melhores" fios.

    captura de tela mostrando a solução

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