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 / 1569074
Accepted
Lluser
Lluser
Asked: 2020-07-17 00:39:52 +0800 CST2020-07-17 00:39:52 +0800 CST 2020-07-17 00:39:52 +0800 CST

Como formatar o código VBA para 80 colunas?

  • 772

Eu tenho algum código VBA onde as linhas são longas e quero enviá-lo para algum lugar, onde é (não 100% estrito) o limite de 80 caracteres on-line.

O VBA permite criar uma quebra de linha de código colocando " _" antes de " enter". (Obviamente, isso não funciona dentro de strings, que devem ser divididas em substrings e conectadas com " &". Como você pode ver abaixo.)

Existe alguma ferramenta para adicionar "quebras de linha" no código automaticamente?
Ou talvez regex?

Tentei pesquisar, mas sem resultados válidos.

Código original:

'Some looooooong comment Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut a volutpat dolor. In risus odio, pharetra a arcu in, efficitur ornare lectus. Maecenas non aliquet leo. Praesent luctus blandit magna, et sagittis ex porta et.
MsgBox("Some text in MsgBox. Donec vulputate eros ac nulla hendrerit auctor. In hac habitasse platea dictumst. Proin fermentum augue elit, eget consequat massa mattis et. Integer semper imperdiet diam sit amet malesuada.", 64, "Title of MsgBox")
'Another comment now with link to doc. https://example.com/?bs64=SWYgeW91IGFyZSBzbWFydCBlbm91Z2ggdG8gZGVjb2RlLCB5b3UgbXVzdCBkZWZpbml0ZWx5IHdhdGNoIHRoaXM6IGh0dHBzOi8vd3d3LnlvdXR1YmUuY29tL3dhdGNoP3Y9b0hnNVNKWVJIQTA=

Código procurado:

'Some looooooong comment Lorem ipsum dolor sit amet, consectetur adipiscing
'elit. Ut a volutpat dolor. In risus odio, pharetra a arcu in, efficitur
'ornare lectus. Maecenas non aliquet leo. Praesent luctus blandit magna, et
'sagittis ex porta et.
MsgBox("Some text in MsgBox. Donec vulputate eros ac nulla hendrerit auctor." _
 & "In hac habitasse platea dictumst. Proin fermentum augue elit, eget " _ 
 & "consequat massa mattis et. Integer semper imperdiet diam sit amet" _
 & " malesuada.", 64, "Title of MsgBox")
'Another comment now with link to doc.
'https://example.com/?bs64=SWYgeW91IGFyZSBzbWFydCBlbm91Z2ggdG8gZGVjb2RlLCB5b3UgbXVzdCBkZWZpbml0ZWx5IHdhdGNoIHRoaXM6IGh0dHBzOi8vd3d3LnlvdXR1YmUuY29tL3dhdGNoP3Y9b0hnNVNKWVJIQTA=

Obrigado.

PS: Estou usando o Notepad++

regex notepad++
  • 1 1 respostas
  • 94 Views

1 respostas

  • Voted
  1. Best Answer
    JvdV
    2020-07-17T01:23:31+08:002020-07-17T01:23:31+08:00

    Talvez você possa usar duas funções de pesquisa e substituição de regex? Um para tratar apenas linhas com comentário e o outro para tratar linhas com MsgBox. Isso deixaria o VBA regular sozinho. O primeiro padrão pode ser:

    ^[^'].*(*SKIP)(*F)|(?:(?:.{1,70}|.{71,140}|.{141,210}|.{211,280})|\G(?!^))\S+\K\h(?=.{25,}$)
    

    Substitua por \n', veja a demonstração online


    O segundo:

    ^(?!MsgBox\().*(*SKIP)(*F)|(?:(?:.{1,70}|.{71,140}|.{141,210}|.{211,280})|\G(?!^))\S+\K\h(?=.{25,}$)
    

    Substitua por " _\n & ", veja a demonstração online


    Uma análise dos princípios do padrão:

    • ^- Linha de partida âncora.
    • [^']- Corresponde a qualquer caractere, exceto uma aspa simples literal.
    • .*- Corresponde a qualquer caractere diferente de zero de nova linha ou mais vezes.
    • (*SKIP)(*F)- Combinação Skip/Fail para consumir o padrão correspondente, mas negá-lo mais tarde.
    • |- Alternação/OU.
    • (?:- Abra o 1º grupo sem captura.
      • (?:- Abrir 2º grupo sem captura.
        • .{1,70}|.{71,140}|.{141,210}|.{211,280}- Alternação para corresponder a qualquer caractere diferente de nova linha uma quantidade x de vezes. Você pode adicionar mais se os valores de string forem ainda mais longos.
        • )- Fechar o segundo grupo aninhado sem captura.
      • |- Alternação/OU.
      • \G(?!^)- Afirmar a posição no final da correspondência anterior com antecipação negativa para evitar o início da posição da string.
      • )- Fechar o 1º grupo sem captura.
    • \S+- Corresponder a pelo menos 1 caractere sem espaço em branco.
    • \K- Redefina o ponto de partida da partida relatada anteriormente.
    • \h- Corresponde a um caractere de espaço em branco horizontal.
    • (?=.{25,}$)- Antecipação positiva para garantir que haja pelo menos mais 25 caracteres até a âncora final da string (para evitar pequenas peças finais).

    Considerando que o padrão acima funcionaria para linhas destinadas a comentários. A única diferença com o segundo padrão é que ele usa um lookahead negativo para garantir que a linha não comece com o literal 'MsgBox('.


    insira a descrição da imagem aqui

    Meu resultado final:

    'Some looooooong comment Lorem ipsum dolor sit amet, consectetur adipiscing 
    'elit. Ut a volutpat dolor. In risus odio, pharetra a arcu in, efficitur 
    'ornare lectus. Maecenas non aliquet leo. Praesent luctus blandit 
    'magna, et sagittis ex porta et.
    MsgBox("Some text in MsgBox. Donec vulputate eros ac nulla hendrerit auctor. " _
     & "In hac habitasse platea dictumst. Proin fermentum augue elit, eget consequat " _
     & "massa mattis et. Integer semper imperdiet diam sit amet " _
     & "malesuada.", 64, "Title of MsgBox")
    'Another comment now with link to doc. 
    'https://example.com/?bs64=SWYgeW91IGFyZSBzbWFydCBlbm91Z2ggdG8gZGVjb2RlLCB5b3UgbXVzdCBkZWZpbml0ZWx5IHdhdGNoIHRoaXM6IGh0dHBzOi8vd3d3LnlvdXR1YmUuY29tL3dhdGNoP3Y9b0hnNVNKWVJIQTA=
    
    • 1

relate perguntas

  • Notepad ++ excluir até dois pontos para cada linha com substituir tudo

  • Existe um .gitignore para OneDrive?

  • NotePad++ User Defined Lang não mostra instruções condicionais

  • Como parar de pesquisar se uma string ocorrer antes de outra string no Regex

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