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 / 1817467
Accepted
Shakir
Shakir
Asked: 2023-11-21 02:45:28 +0800 CST2023-11-21 02:45:28 +0800 CST 2023-11-21 02:45:28 +0800 CST

Macro para manter 3 linhas visíveis sob a linha selecionada no LibreOffice Calc

  • 772

No Calc ou MS Excel, quando terminar de editar uma célula em uma linha, pressionar Enter leva à próxima linha abaixo. Continue fazendo isso e eventualmente você chegará à última linha visível na tela. Aqui, quando você pressiona Enter, isso levará à próxima linha, mas agora é a última linha. É difícil ver a última linha em telas como os óculos Nreal Air (já que a parte inferior está sempre desfocada). Minha solução foi manter a linha atualmente selecionada no meio. Isso significa que sempre que Enter for pressionado, uma macro verificará quantas linhas estão visíveis na linha recém-selecionada. Se for menor que 3, as linhas visíveis irão subir (mantendo assim a linha selecionada no meio). A seguiras respostas resolvem exatamente esse problema no MS Excel. Eu gostaria de fazer o mesmo no LibreOffice Calc. No entanto, até agora não tive sucesso em escrever uma macro que verifica as linhas visíveis sob a linha selecionada e adiciona uma nova linha toda vez que pressiono Enter (mantendo assim a próxima linha selecionada no meio da tela). Alguma ideia de como fazer isso no Calc?

python
  • 1 1 respostas
  • 26 Views

1 respostas

  • Voted
  1. Best Answer
    JohnSUN
    2023-11-21T17:28:35+08:002023-11-21T17:28:35+08:00

    Sua tarefa não é difícil de implementar - na verdade, você só precisa usar o método .setFirstVisibleRow() para alterar a área de exibição levando em consideração os valores da "linha atual" e da "última linha visível". Por exemplo, esta macro pode fazer isto:

    Sub onSelectionChanged(Optional oEvent As Variant)
    Dim oCurrentController As Variant
    Dim arrayOfString() As String, tmpString As String
    Dim aVisibleRange As New com.sun.star.table.CellRangeAddress
    Dim nSheet As Integer,  nStartRow As Long,  nEndRow As Long, nCurrentRow As Long
        oCurrentController = ThisComponent.getCurrentController()
        aVisibleRange = oCurrentController.getVisibleRange()
        nSheet = aVisibleRange.Sheet
        nStartRow = aVisibleRange.StartRow
        nEndRow = aVisibleRange.EndRow
        arrayOfString = Split(oCurrentController.getViewData(), ";")
        If UBound(arrayOfString) < (3 + nSheet) Then Exit Sub
        tmpString = arrayOfString(3 + nSheet)
        If InStr(tmpString,"+") > 0 Then
            arrayOfString() = Split(tmpString, "+")
        Else
            arrayOfString() = Split(tmpString, "/")
        EndIf
        nCurrentRow = CLng(arrayOfString(1))
        If nEndRow - nCurrentRow < 4 Then  oCurrentController.setFirstVisibleRow(nStartRow + nCurrentRow - nEndRow + 3)
    End Sub
    

    A principal dificuldade está em escolher como executar esta macro. Por exemplo, você pode atribuir esse script como um manipulador para o evento "Seleção alterada".

    Definir ouvinte de eventos

    Mas, neste caso, a macro só funcionará para as planilhas às quais está atribuída. (A propósito, a solução Excel a que você se refere na sua pergunta funciona exatamente da mesma forma - apenas para a planilha especificada).

    Você pode pensar em algum tipo de macro geral que, ao abrir qualquer planilha, atribuirá esse ouvinte de evento a todas as planilhas e o atribuirá a todo o pacote de escritório .

    • 0

relate perguntas

  • Conda quebra ao ativar o ambiente -- CommandNotFoundError: Nenhum comando 'conda conda'

  • Documentação do Notepad++ e Python

  • SCons construídos com desenvolvimento gcc8

  • Matplotlib - Erro de instalação do mapa base

  • pip não vai atualizar ou instalar módulos corretamente

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