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 / 1515531
Accepted
PeterH
PeterH
Asked: 2020-01-09 01:21:40 +0800 CST2020-01-09 01:21:40 +0800 CST 2020-01-09 01:21:40 +0800 CST

Oposto de FORMULATEXT no Excel

  • 772

Existe uma função que faz o oposto deFORMULATEXT

Por exemplo no Cell B2eu tenho:

='[Workshop Schedule 2020.xlsx]Lisburn'!D7

Em C2i estou usando FORMULATEXTe REPLACE, para substituir LISBURN por CANNOCK:

=REPLACE(FORMULATEXT(B2),32,7,"CANNOCK")

Que retorna o abaixo como uma string.

='[Workshop Schedule 2020.xlsx]CANNOCK'!D7

Agora quero usar essa string como uma fórmula. Não consigo usar INDIRECT, pois aponta para uma pasta de trabalho externa.

microsoft-excel worksheet-function
  • 2 2 respostas
  • 5887 Views

2 respostas

  • Voted
  1. Best Answer
    Gary's Student
    2020-01-09T05:07:08+08:002020-01-09T05:07:08+08:00

    Você poderia criar uma função definida pelo usuário como:

    Public Function eval(s As String) As Variant
        eval = Evaluate(s)
    End Function
    

    Portanto, se A1 contiver a string de texto:

    =1/2 & " some text"
    

    Então:

    insira a descrição da imagem aqui

    As funções definidas pelo usuário (UDFs) são muito fáceis de instalar e usar:

    1. ALT-F11 abre a janela do VBE
    2. ALT-I ALT-M abre um novo módulo
    3. cole o material e feche a janela do VBE

    Se você salvar a pasta de trabalho, a UDF será salva com ela. Se você estiver usando uma versão do Excel posterior a 2003, salve o arquivo como .xlsm em vez de .xlsx

    Para remover o UDF:

    1. abrir a janela do VBE como acima
    2. limpe o código
    3. feche a janela do VBE

    Para usar o UDF do Excel:

    =eval(A1)
    

    Para saber mais sobre macros em geral, consulte:

    http://www.mvps.org/dmcritchie/excel/getstarted.htm

    e

    http://msdn.microsoft.com/en-us/library/ee814735(v=office.14).aspx

    e para detalhes sobre UDFs, consulte:

    http://www.cpearson.com/excel/WritingFunctionsInVBA.aspx

    As macros devem estar habilitadas para que isso funcione!

    • 2
  2. Jeorje
    2020-01-10T19:04:39+08:002020-01-10T19:04:39+08:00

    Elogio sua vontade de usar VBA e UDFs que facilitam tantas coisas. As UDFs são um ótimo lugar para se familiarizar com o VBA para aqueles que não são, portanto, é um uso de gateway e, muitas vezes, uma ótima solução.

    Você PODE fazer isso sem um UDF, se desejar. Muito rápido de fazer e não requer planejamento de abordagem como uma UDF costuma fazer, pois você deixará o Excel fazer o trabalho de descobrir como avaliar o resultado.

    Também tem o objetivo de ser um Sim direto ao seu desejo de algo semelhante à INDIRECT()função.

    Você pode usar a função de linguagem macro antiga (25 anos) EVALUATE. Está disponível, MAS APENAS NA FUNÇÃO DE INTERVALO NOMEADO. (E em macros, mas uma boa macro já foi feita pelo Gary's Student.) Digitar a função na própria planilha falhará.

    Crie um Named Range(talvez chamado de "horsey"). Para o seu Refers tovalor insira a seguinte fórmula:

    =EVALUATE(C2)
    

    e salve as coisas, fechando o gerenciador de intervalos nomeados.

    Agora digitando

    =horsey
    

    em QUALQUER célula da planilha (bem, exceto B2 e C2!) fará exatamente o INDIRECT()que faria com uma referência de célula. Ele pega a string (incluindo o "=" ou NÃO incluindo não faz diferença) em C2 e a trata como uma fórmula.

    As pessoas geralmente pensam EVALUATE()no papel restrito de transformar alguma entrada de célula 17-5+32em um resultado calculado, mesmo que seja texto e não tenha sinal de igual, então eles acham que não tem grande valor. Mas pode fazer coisas muito mais complicadas, como exatamente o que você está pedindo hoje.

    Especialmente porque agora FORMULATEXT()podemos modificar facilmente as fórmulas de trabalho.

    • 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
    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
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +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