Textliste mit entsprechendem Schlüssel in Tabellenkalkulation formatieren

Textliste mit entsprechendem Schlüssel in Tabellenkalkulation formatieren

Ich habe eine Textdatei mit entsprechend angeordneten Daten.

name1
2010-01-02 (i)
2010-05-07 (i)
2010-06-12 (i)
name2
2010-01-02 (i)
2010-05-07 (i)
2010-06-12 (i)
name3
2011-01-05 (i)
2011-05-05 (i)
2011-06-14 (i)

Gibt es eine Funktion oder Möglichkeit, die Daten in einer Tabelle mit zwei Spalten wie folgt anzuordnen:

+---------------+-----+
| 2010-01-02 (i)|name1|
| 2010-05-07 (i)|name1|
| 2010-06-12 (i)|name1|  
| 2010-01-02 (i)|name2|
| 2010-05-07 (i)|name2|
| 2010-06-12 (i)|name2|
| 2011-01-05 (i)|name3|
| 2011-05-05 (i)|name3|
| 2011-06-14 (i)|name3|
+---------------+-----+

Damit die Artikel sortiert und gezählt werden können?

Bearbeiten
Ich glaube, ich muss ein Makro schreiben, das durch Spalte A laufen kann

  1. !Wenn "()"
  2. Zelle ausschneiden
  3. andernfalls Zelle B einfügen

Antwort1

Vorausgesetzt, die Daten stehen in Spalte A von Blatt1, funktioniert Folgendes:

Rem Attribute VBA_ModuleType=VBAModule
Option VBASupport 1
Option Explicit
Sub rearrange()
    Dim elements As Integer, rowIndex As Integer, i As Integer
    Dim Name As String
'   LO Basic additions
    Dim Doc As Object
    Dim Sheet As Object
    dim cell as object
    Doc = ThisComponent
    Sheet = Doc.Sheets.getByName("Sheet1")

    Cell = Sheet.getCellRangeByName("D1")

    Cell.formula = "=COUNTA(A1:A104586)"

    elements = cell.value
    rowIndex = 1
    For i = 1 To elements
        If Right(Range("A" & i), 3) <> "(i)" Then
            Name = Range("A" & i)
        Else
            Range("B" & rowIndex) = Name
            Range("C" & rowIndex) = Range("A" & i)
            rowIndex = rowIndex + 1
        End If
    Next
End Sub

verwandte Informationen