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 / 1743895
Accepted
BmyGuest
BmyGuest
Asked: 2022-09-24 00:16:49 +0800 CST2022-09-24 00:16:49 +0800 CST 2022-09-24 00:16:49 +0800 CST

Como posso reordenar melhor os dados no formato misto de linha/coluna em uma tabela simples?

  • 772

Eu tenho (de um arquivo CVS) dados no seguinte formato:

Os dados são uma lista contínua (linha por linha de valores separados por vírgulas) onde em locais arbitrários as colunas são inseridas ou removidas. Nessas ocasiões, uma nova linha de 'cabeçalho' é adicionada. A primeira coluna é sempre a data. Uma importação direta ficaria assim:

Formato da tabela de fonte de dados

Agora, o que eu precisaria para uma avaliação de dados adicional é uma tabela como a seguinte: Formato de tabela de dados desejado

Como tenho muitos dados nesse formato, o rearranjo manual não é uma opção.

Como posso conseguir este recurso automaticamente?

Ou por importação de consulta do arquivo CVS para o Excel ou por manipulação subsequente do Excel?

microsoft-excel worksheet-function
  • 1 1 respostas
  • 29 Views

1 respostas

  • Voted
  1. Best Answer
    JohnSUN
    2022-09-24T04:06:28+08:002022-09-24T04:06:28+08:00

    Do ponto de vista dos computadores e da teoria de banco de dados relacional, é muito melhor transformar seus dados mistos desta forma:

    Formulário de nova tabela

    Este trabalho pode ser feito rapidamente pelo seguinte script:

    Option Explicit
    
    Sub repackMixedData()
    Dim sheet As Worksheet
    Dim rSource As Range
    Dim rRow As Range
    Dim rHeader As Range
    Dim oCellDate As Range
    Dim oCell As Range
    Dim oTargetCell As Range
        Set sheet = ActiveSheet
        Set rSource = sheet.UsedRange
        Set sheet = ThisWorkbook.Worksheets.Add()
        Set oTargetCell = sheet.Range("A1")
        With oTargetCell.Resize(1, 3)
            .Value = Array("Date", "Item", "Value")
            .Font.Bold = True
        End With
        For Each rRow In rSource.Rows
            Set oCellDate = rRow.Cells(1)
            If oCellDate = "Date" Then
                Set rHeader = rRow
            Else
                For Each oCell In rRow.Offset(0, 1).Cells
                    If Not IsEmpty(oCell) Then
                        Set oTargetCell = oTargetCell.Offset(1, 0)
                        oTargetCell.Value2 = oCellDate.Value2
                        oTargetCell.NumberFormat = oCellDate.NumberFormat
                        oTargetCell.Offset(0, 1) = rHeader.Cells(1, oCell.Column).Text
                        oTargetCell.Offset(0, 2) = oCell.Value
                    End If
                Next oCell
            End If
        Next rRow
    End Sub
    

    E com a tabela "plana" resultante, você pode fazer qualquer coisa, por exemplo, criar uma tabela dinâmica e obter um resultado semelhante à sua segunda captura de tela.

    Atualização Desde que se descobriu que há muito mais dados reais do que o esperado, a macro foi ligeiramente melhorada. Por favor, tente esta opção - deve ser um pouco mais rápido.

    Sub repackMixedData2()
    Dim sheet As Worksheet
    Dim rSource As Range
    Dim rRow As Range
    Dim rHeader As Range
    Dim oCellDate As Range
    Dim oCell As Range
    Dim countOfValues As Long
    Dim arrResult As Variant
    Dim index As Long
        Set sheet = ActiveSheet
        Set rSource = sheet.UsedRange
        countOfValues = Application.WorksheetFunction.CountA(rSource.Offset(0, 1))
    ReDim arrResult(1 To countOfValues, 1 To 3) As Variant
        index = 1
        arrResult(index, 1) = "Date"
        arrResult(index, 2) = "Item"
        arrResult(index, 3) = "Value"
        For Each rRow In rSource.Rows
            Set oCellDate = rRow.Cells(1)
            If oCellDate = "Date" Then
                Set rHeader = rRow
            Else
                For Each oCell In rRow.Offset(0, 1).Cells
                    If IsEmpty(oCell) Then Exit For
                    index = index + 1
                    arrResult(index, 1) = oCellDate.Value2
                    arrResult(index, 2) = rHeader.Cells(1, oCell.Column).Text
                    arrResult(index, 3) = oCell.Value
                Next oCell
            End If
        Next rRow
        
        Set sheet = ThisWorkbook.Worksheets.Add()
        sheet.Range("A1:C" & index).Value2 = arrResult
        sheet.Range("A1:C1").Font.Bold = True
        sheet.Range("A:A").NumberFormat = oCellDate.NumberFormat
    End Sub
    
    • 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
    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