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 / 1653458
Accepted
Bob Weeks
Bob Weeks
Asked: 2021-06-04 06:23:57 +0800 CST2021-06-04 06:23:57 +0800 CST 2021-06-04 06:23:57 +0800 CST

Excel, crie uma nova janela com as mesmas configurações

  • 772

Ao criar uma nova janela para uma pasta de trabalho existente, algumas configurações não são transferidas para a nova janela. O mais importante para mim são as configurações de painel, linha e coluna congelados, juntamente com a visibilidade das linhas de grade. Outros relataram outras configurações não sendo observadas. Alguns descreveram uma solução usando macros, mas isso parece uma complexidade extra para algo que espero ter uma solução simples.

Isso ocorre ao usar a opção Exibir | Novo comando de janela em uma pasta de trabalho existente.

microsoft-excel
  • 1 1 respostas
  • 357 Views

1 respostas

  • Voted
  1. Best Answer
    harrymc
    2021-06-04T06:47:55+08:002021-06-04T06:47:55+08:00

    É assim que o Excel funciona e pode ser um bug ou um "recurso". Não pode ser resolvido usando a GUI do Excel, portanto, é necessária uma macro VBA.

    O artigo Gridlines & Freeze Panes Settings Lost in New Window – How to Fix It descreve o problema e contém a solução como uma macro VBA que faz o seguinte:

    • Criar a nova janela
    • Percorre todas as planilhas na nova janela e aplica o seguinte da janela original: Linhas de grade, Congelar painéis e Títulos.
    • Ativa a folha original na janela original e nova
    • Organize as janelas na exibição de tela dividida vertical lado a lado
    • Role até a guia ativa na pasta de trabalho para poder visualizá-la.

    Caso o artigo desapareça no futuro, aqui está o código VBA:

    Sub New_Window_Preserve_Settings()
    'Create a new window and apply the grid line settings
    'for each sheet.
    
    Dim ws As Worksheet
    Dim i As Long
    Dim iWinCnt As Long
    Dim bGrid As Boolean
    Dim bPanes As Boolean
    Dim bHeadings As Boolean
    Dim iSplitRow As Long
    Dim iSplitCol As Long
    Dim iActive As Long
    Dim iZoom As Long
    Dim sSep As String
    
      Application.ScreenUpdating = False
    
      'Store the active sheet
      iActive = ActiveSheet.Index
    
      'Create new window
      ActiveWindow.NewWindow
      iWinCnt = ActiveWorkbook.Windows.Count
      
      'Set the separator based on the version of Excel
      'Office 365 now using a dash
      If InStr(":", ActiveWorkbook.Name) > 0 Then
        sSep = ":"
      Else
        sSep = "  -  "
      End If
      
      'Loop through worksheets of original workbook
      'and apply grid line settings to each sheet.
      For Each ws In ActiveWorkbook.Worksheets
        Windows(ActiveWorkbook.Name & sSep & "1").Activate
        ws.Activate
        
        'Store the properties
        bGrid = ActiveWindow.DisplayGridlines
        bHeadings = ActiveWindow.DisplayHeadings
        iZoom = ActiveWindow.Zoom
        
        'Get freeze panes
        bPanes = ActiveWindow.FreezePanes
        If bPanes Then
           iSplitRow = ActiveWindow.SplitRow
           iSplitCol = ActiveWindow.SplitColumn
        End If
        
        'Activate the new window and sheet in loop
        Windows(ActiveWorkbook.Name & sSep & iWinCnt).Activate
        Worksheets(ws.Index).Activate
        
        'Set properties
        With ActiveWindow
          .DisplayGridlines = bGrid
          .DisplayHeadings = bHeadings
          .Zoom = iZoom
          If bPanes Then
            .SplitRow = iSplitRow
            .SplitColumn = iSplitCol
            .FreezePanes = True
          End If
        End With
      Next ws
        
      'Activate original active sheet for the new window
      Worksheets(iActive).Activate
      
      'Activate the original active sheet for the original window
      Windows(ActiveWorkbook.Name & sSep & "1").Activate
      Worksheets(iActive).Activate
      
      'Split Screen View (optional)
      'The following section can be commented out if you don't want split screen.
      
        'Turn screen updating on for split screen
        Application.ScreenUpdating = True
         
        For i = iWinCnt To 1 Step -1
          Windows(ActiveWorkbook.Name & sSep & i).Activate
        Next i
        
        'Split view side-by-side vertical
        ActiveWorkbook.Windows.Arrange ArrangeStyle:=xlVertical
        
        'Scroll to active tab in original window
        ActiveWindow.ScrollWorkbookTabs Position:=xlFirst
        ActiveWindow.ScrollWorkbookTabs Sheets:=iActive
        
        'Scroll to active tab in new window
        Windows(ActiveWorkbook.Name & sSep & iWinCnt).Activate
        DoEvents
        ActiveWindow.ScrollWorkbookTabs Position:=xlFirst
        ActiveWindow.ScrollWorkbookTabs Sheets:=iActive
      
    End Sub
    

    O artigo também contém uma macro VBA para fechar as janelas adicionais, para que elas não sejam salvas por engano e substituam a pasta de trabalho original:

    Sub Close_Additional_Windows()
    'Close additional windows and maximize original
    
    Dim i As Long
    Dim sSep As String
    
      'Set the separator based on the version of Excel
      'Office 365 now using a dash
      If InStr(":", ActiveWorkbook.Name) > 0 Then
        sSep = ":"
      Else
        sSep = "  -  "
      End If
      
      If ActiveWorkbook.Windows.Count > 1 Then
        For i = ActiveWorkbook.Windows.Count To 2 Step -1
          Windows(ActiveWorkbook.Name & sSep & i).Close
        Next i
      End If
      
      Windows(ActiveWorkbook.Name).WindowState = xlMaximized
    
    End Sub
    

    O artigo também contém uma seção sobre como instalar as macros em sua pasta de trabalho, caso você nunca tenha trabalhado com VBA.

    • 2

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