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 / 1424891
Accepted
Jorda
Jorda
Asked: 2019-04-13 14:10:10 +0800 CST2019-04-13 14:10:10 +0800 CST 2019-04-13 14:10:10 +0800 CST

Empilhe cada enésima coluna uma sob a outra

  • 772

Isso pode ser um problema trivial, mas não consigo descobrir. Eu tenho um conjunto de dados que possui colunas duplicadas e preciso descobrir uma maneira de empilhar cada n-ésima coluna uma abaixo da outra. Então, se considerarmos isso:

dados originais

Podemos ver que temos colunas duplicadas, preciso que meus dados sejam empilhados um embaixo do outro assim:

depois

Minhas colunas duplicadas são uma constante, então sempre terei 5 colunas duplicadas. Qualquer ajuda neste assunto seria altamente apreciada!

microsoft-excel macros
  • 1 1 respostas
  • 1200 Views

1 respostas

  • Voted
  1. Best Answer
    Alex M
    2019-04-13T15:16:34+08:002019-04-13T15:16:34+08:00

    OFFSETVocê precisa de uma fórmula cíclica aqui.

    CONFIGURAR

    Portanto, temos uma linha de cabeçalho e dados, digamos, A2:ZZZZ38. Vamos apenas colocar isso Sheet1. Vamos configurar nossa saída em Sheet2.

    PRECIS

    Conceitualmente, podemos entender facilmente que queremos Sheet2!A2(doravante chamaremos esta célula apenas A2para simplificar) reproduzir Sheet1!A2. Em A3queremos a próxima célula abaixo, e assim por diante - até que tenhamos examinado todos os registros em Sheet1!A, e então queremos voltar para a primeira linha, mas em 5 colunas.

    Este é claramente um caso para OFFSET.

    FÓRMULA

    =OFFSET(Sheet1!A$2,MOD(ROW()-2,COUNTA(Sheet1!A:A)-1),ROUNDDOWN((ROW()-2)/(COUNTA(Sheet1!A:A)-1),0)*5)

    DEMO

    Meus dados são um pouco menores que os seus; apenas grande o suficiente para provar o conceito.

    Aqui está Sheet1:

    insira a descrição da imagem aqui

    E a saída Sheet2:

    insira a descrição da imagem aqui

    EXPLICAÇÃO

    OFFSETtem três partes. Onde começar, quantas linhas descer (deslocamento vertical) e quantas colunas ultrapassar (deslocamento horizontal).

    A- por onde começar

    Sheet1!A$2

    Bem direto.

    B - deslocamento de linhas

    MOD(ROW()-2,COUNTA(Sheet1!A:A)-1)

    Descubra em que linha estamos e subtraia 2 (estamos começando em A2, e queremos A2ser o deslocamento zero). Divida isso por quantos registros estamos contando (o -1aqui representa a exibição da linha de cabeçalho) e pegue o restante. Isso simplesmente produz uma função que conta de 0até [n-1]onde n é o número de linhas e começa novamente em 0.

    Em outras palavras, para uma tabela com 8 registros, isso retorna:

    0, 1, 2, 3, 4, 5, 6, 7, 0, 1, 2, 3, 4, 5, 6, 7, 0 ...

    C - deslocamento de colunas

    ROUNDDOWN((ROW()-2)/(COUNTA(Sheet1!A:A)-1),0)*5

    Pegue ROW()-2novamente e divida pela contagem de registros novamente - mas desta vez, em vez de pegar o MOD(restante) desse relacionamento, queremos apenas arredondá-lo para o inteiro mais próximo. Isso nos dá uma sequência que consiste em um número de 0 igual à contagem de registros, seguido por um número de 1, 2, etc. Em seguida, multiplique por 5 (consulte a observação abaixo). Isso fornece nosso deslocamento de coluna - toda vez que a contagem cíclica de linhas é redefinida, saltamos outras 5 colunas.

    Em outras palavras, para uma tabela com 8 registros, isso retorna:

    0, 0, 0, 0, 0, 0, 0, 0, 5, 5, 5, 5, 5, 5, 5, 5, 10 ...

    FÓRMULA, NOVAMENTE:

    =OFFSET(Sheet1!A$2,MOD(ROW()-2,COUNTA(Sheet1!A:A)-1),ROUNDDOWN((ROW()-2)/(COUNTA(Sheet1!A:A)-1),0)*5)

    Isso entra Sheet2!A2e copia para A:Ee para baixo sem restrição.

    NB

    1. O 5 é codificado, porque você declarou como uma propriedade de seus dados que as colunas se repetem por 5. Isso pode ser expandido em uma função dinâmica, se necessário (ou, é claro, simplesmente alterado se houver um número fixo de repetidos colunas que não são 5). Isso pode ser uma pergunta para outro dia.
    2. Apesar do enorme tamanho do arquivo, essa fórmula não deve demorar para ser processada. Ele inclui uma referência de coluna inteira, mas dentro de uma COUNTAnão acho que isso irá atrasá-lo. Em caso afirmativo, você pode alterar facilmente cada instância de COUNTA(Sheet1!A:A)para COUNTA(Sheet1!A2:A38), pois tecnicamente já sabemos o tamanho dos dados, ou simplesmente codificar esse valor para 37, o que funcionará desde que você tenha exatamente 37 linhas.
    3. Metade do tempo que levei para acertar isso foi sendo cuidadoso com a ordem das operações aritméticas e dividindo as partes da fórmula em colunas diferentes para solucionar o problema que estava tendo - que acabou sendo um par de parênteses ausente. Na verdade, isso é muito simples; é apenas uma questão de saber que OFFSETexiste e então elaborar a lógica/aritmética para entender como produzir a sequência de pares que você precisa compensar.
    • 3

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

    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

    Serviço do Windows 10 chamado AarSvc_70f961. O que é e como posso desativá-lo?

    • 2 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
  • Marko Smith

    ssl.SSLCertVerificationError: falha na verificação do certificado [SSL: CERTIFICATE_VERIFY_FAILED]: não foi possível obter o certificado do emissor local (_ssl.c:1056)

    • 4 respostas
  • Marko Smith

    Como posso saber em qual unidade o Windows está instalado?

    • 6 respostas
  • Martin Hope
    Albin Como faço para ativar o WindowsXP agora que o suporte acabou? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch O Windows 10 exclui muitos arquivos minúsculos muito lentamente. Algo pode ser feito para agilizar? 2019-09-23 06:05:43 +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
    Inter Sys Como Ctrl+C e Ctrl+V funcionam? 2019-05-15 02:51:21 +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