Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

gelöst Excel - Daten aus einer Zeile in mehrere Zeilen aufteilen

Mitglied: ovu-p86

ovu-p86 (Level 1) - Jetzt verbinden

09.01.2014 um 12:45 Uhr, 11175 Aufrufe, 4 Kommentare, 2 Danke

Hallo,

Folgendes bekomme ich nicht gelöst:
Muss eine Excel-Tabelle in eine andere Form übertragen. Arbeite mit Excel 2k.

Die Urtabelle beinhaltet je Artikel alle Staffeln u. dazugehörige Preise in einer Zeile.
Die Anzahl der Staffeln ist unterschiedlich.

Das muss ich umwandeln in eine Tabelle in der jeweils Artikel u. nur eine Staffel mit dem
dazugehörige Preis
steht und das separat in einer Zeile.

Da es sich um 600 Artikel handelt, suche ich eine Formel- oder und VBA-Lösung.

Zur Verdeutlichung, Beispiel:

4bb4061b2f0adf26939adb2b619abb10 - Klicke auf das Bild, um es zu vergrößern



Für Anregungen, Konzepte und Lösungen bin ich dankbar.

Gruß
Uwe
Mitglied: colinardo
LÖSUNG 09.01.2014, aktualisiert um 16:35 Uhr
Hallo Uwe,
nach deiner Beispiel-Tabelle im Bild und bei 5 Staffeln kannst du es so mit VBA machen:
(Du musst natürlich für deine echte Tabelle die Start-Ausgabe-Zelle in Zeile 6 des Codes anpassen und eventuell die Start-Zelle der Artikelliste in Zeile 4.)
01.
Sub ListeGenerieren()
02.
    Dim sheet As Worksheet, rngOutCurrent As Range, rngInCurrent As Range, rngInStop As Range, rngInStart As Range
03.
    Set sheet = Worksheets("Tabelle1")
04.
    Set rngInStart = sheet.Range("A6")
05.
    Set rngInStop = rngInStart.End(xlDown)
06.
    Set rngOutCurrent = sheet.Range("A15")
07.
    Set rngInCurrent = rngInStart
08.

09.
    For Each cell In sheet.Range(rngInStart, rngInStop)
10.
        For i = 1 To 10 Step 2
11.
            If rngInCurrent.Offset(0, i).Value <> "" Then
12.
                rngOutCurrent.Value = rngInCurrent.Value
13.
                rngOutCurrent.Offset(0, 1).Value = rngInCurrent.Offset(0, i).Value
14.
                rngOutCurrent.Offset(0, 2).Value = rngInCurrent.Offset(0, i + 1).Value
15.
                Set rngOutCurrent = rngOutCurrent.Offset(1, 0)
16.
            End If
17.
        Next
18.
        Set rngInCurrent = rngInCurrent.Offset(1, 0)
19.
    Next
20.
End Sub
Hier auch ein Demo-Sheet dazu.

Grüße Uwe
Bitte warten ..
Mitglied: ovu-p86
09.01.2014 um 15:38 Uhr
Hallo colinardo,

habs gleich probiert.

Perfekt. Hat sofort geklappt

Danke, hatte überhaupt nicht mit sowas konkretem gerechnet.

Jetzt muss ich erstmal deinen Code verstehen.
Ich muss noch folgendes anpassen:

1. zwischen Spalte A und B existieren real noch 2 zusätzliche Spalten die nicht ausgewertet werden müssen
(muss ich wohl was an den Offsets machen, aber ist ja ne Lücke?)
2. es sind maximal 8 Staffeln
(wahrscheinlich "For i = 1 To 16)
3. Ergebnis soll in neues Arbeitsblatt (Tabelle2) geschrieben werden
(ist wohl komplizierter)
4. Im Ergebnis soll eine weitere Spalte mit immer gleichem Text erscheinen
(mach ich wohl mit Befehl "einfügen Spalte, u.s.w.)

also so:

d3f4e6f159f002446f1e7caa9d1755be - Klicke auf das Bild, um es zu vergrößern

Das hatte ich in der Frage weggelassen, um es nicht noch komplizierter zu machen.
Aber da wusele ich mich schon durch.

Kann den Beitrag im Prinzip auf "gelöst" setzen.
Warte nur noch ein bißchen, falls sich noch eine Frage ergibt.

Nochmals Dank.

Gruß
Uwe
Bitte warten ..
Mitglied: colinardo
LÖSUNG 09.01.2014, aktualisiert um 16:34 Uhr
kein Problem, hab's dir zusätzlich mit Kommentaren im Code versehen ...
(hab noch eine Variable entfernt die überflüssig war)
Die Liste wird nun in "Tabelle2" ab Zelle "A2" ausgegeben.
01.
Sub ListeGenerieren()
02.
    Dim sheet As Worksheet, rngOutCurrent As Range, rngInStop As Range, rngInStart As Range
03.
    'Arbeitsblatt in dem die Artikel stehen
04.
    Set sheet = Worksheets("Tabelle1")
05.
    'Anfangszelle der Artikel setzen
06.
    Set rngInStart = sheet.Range("A6")
07.
    'Den letzen Artikel finden
08.
    Set rngInStop = rngInStart.End(xlDown)
09.
    'Ausgabe-Startzelle setzen
10.
    Set rngOutCurrent = Worksheets("Tabelle2").Range("A2")
11.
    'Für jeden Artikel im Eingabebereich...
12.
    For Each cell In sheet.Range(rngInStart, rngInStop)
13.
        ' Für jede Staffel ...
14.
        For i = 3 To 19 Step 2
15.
            'Wenn die Menge der Staffel nicht leer ist dann ...
16.
            If cell.Offset(0, i).Value <> "" Then
17.
                'Artikelnamen schreiben
18.
                rngOutCurrent.Value = cell.Value
19.
                'Konstanten Wert 'Staffelpreis' schreiben
20.
                rngOutCurrent.Offset(0, 1).Value = "Staffelpreis"
21.
                'Menge schreiben
22.
                rngOutCurrent.Offset(0, 2).Value = cell.Offset(0, i).Value
23.
                'Preis schreiben
24.
                rngOutCurrent.Offset(0, 3).Value = cell.Offset(0, i + 1).Value
25.
                'Ausgabezeile um eine Zeile nach unten verschieben für den nächsten Eintrag
26.
                Set rngOutCurrent = rngOutCurrent.Offset(1, 0)
27.
            End If
28.
        Next
29.
    Next
30.
End Sub
Jetzt kannste früher Feierabend machen

Grüße Uwe
Bitte warten ..
Mitglied: ovu-p86
09.01.2014 um 16:32 Uhr
Hallo colinardo,

funktioniert sofort.

Das mit den Kommentaren ist klasse. Dann kann ich mal nachvollziehen und auch was lernen.


Also, RiesenDank

Gruß
Uwe
Bitte warten ..
Ähnliche Inhalte
Microsoft Office

Mehr als 20 Excel Dateien öffnen gleichzeitig

Frage von PizzaPepperoniMicrosoft Office7 Kommentare

Hallo. Weiß jemand den Reg Key, wo man einstellt, dass man mehr als 20 Excel Dateien gleichzeitig öffnen kann? ...

Microsoft Office

Excel-Files funktionieren im PDF keine Hyperlinks mehr

Frage von Bommi1961Microsoft Office18 Kommentare

Hallo zusammen, nach Umwandlung meines Excel-Files funktionieren im PDF nicht alle Hyperlinks. Die Textfelder, die ich im Excel mit ...

Microsoft Office

Excel Formel - WENN mit mehr als 3 Kriterien

gelöst Frage von fuguMicrosoft Office2 Kommentare

Hallo an alle Office- und besonders Excel-Spezis :-) Ich breche mir gerade die Finger an einer Formel mit mehr ...

Microsoft Office

Excel 2019 SVERWEIS bei mehr als 10.000 Zeilen

Frage von FunkysiteMicrosoft Office6 Kommentare

Ich habe beim Anwenden der Formel SVERWEIS bei mehr als 10.000 Zeilen nur 9.999 Treffer, es sollten aber alle ...

Neue Wissensbeiträge
Viren und Trojaner

Staatstrojaner soll auch per Einbruch installiert werden können

Information von transocean vor 1 TagViren und Trojaner2 Kommentare

Moin, Bundesinnenminister Horst Seehofer will dem Verfassungsschutz Wohnungseinbrüche erlauben, um den geplanten Staatstrojaner zu installieren. Gruß Uwe

Windows 7
Win7 Update scheitert KB4512506
Information von infowars vor 1 TagWindows 7

Falls jemand auch das Problem hat mit dem: Monatliches Sicherheitsqualitätsrollup für Windows 7 für x64-basierte-Systeme (KB4512506) Das scheint mit ...

Humor (lol)
Wenn hacken nach hinten los geht
Information von em-pie vor 2 TagenHumor (lol)5 Kommentare

Moin, weil heute Freitag ist, nachfolgender kurzer Artikel zum schmunzeln:) l+f: NULL ist ein notorischer Falschparker

Windows Update
Windows: August 2019 Patchday-Probleme
Information von kgborn vor 3 TagenWindows Update3 Kommentare

Ich kippe mal einige kurze Informationen hier rein - vielleicht hilft es Betroffenen. Die August 2019-Updates für Windows haben ...

Heiß diskutierte Inhalte
Switche und Hubs
Glasfaser-Anschluss Telekom muss verteilt werden
Frage von cansoniSwitche und Hubs28 Kommentare

Vorweg: Bin nur Anwender und kein Experte Die Situation: Der Vermieter stellt einen Glasfaseranschluss in der Wohnung bereit. Wir ...

Hyper-V
VMs von Hyper-V auf externer Festplatte
Frage von SnowbirdHyper-V17 Kommentare

Hallo, ich möchte gerne von VirtualBox auf Hyper-V umsteigen und würde auch gerne weiterhin meine VMs auf der externen ...

Ubuntu
Download manchmal langsam oder komplette Abbrüche bzw. Videos spielen nicht bis zum Schluss
Frage von stefanstpUbuntu16 Kommentare

Immer wieder berichten unsere Kunden, dass Downloads abbrechen oder super langsam sind oder Videos nicht abgespielt werden können bzw. ...

Festplatten, SSD, Raid
SSDs durch Lagerung ohne Strom nach 6 Monaten defekt?!?
gelöst Frage von GlobetrotterFestplatten, SSD, Raid13 Kommentare

Moin Gemeinde Ich hatte gerade nen Trauerspiel Habe hier etliche NAS-Geräte herumfahren welche ich mal auf die Seite gelegt ...