Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  SIMULIA/ABAQUS
  Python: rekursive Include-Struktur auflösen?

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
Autor Thema:  Python: rekursive Include-Struktur auflösen? (990 mal gelesen)
HerrHansen
Mitglied
Dipl.-Ing.


Sehen Sie sich das Profil von HerrHansen an!   Senden Sie eine Private Message an HerrHansen  Schreiben Sie einen Gästebucheintrag für HerrHansen

Beiträge: 257
Registriert: 03.12.2005

Abaqus/CAE 6.3 bis 6.12

erstellt am: 23. Jul. 2010 14:28    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Liebe Gemeinde,

gegeben seien drei Listen:

Code:

Liste_1=[1,include_Liste_2,2,3]
Liste_2=[11,include_Liste_3,22,include_Liste_3,33]
Liste_3=[111,222,333]

Welchen Code würdet ihr hier anwenden, sodass es am Ende folgende Liste herauskommt?:

Code:

Liste=[1,11,111,222,333,22,111,222,333,33,2,3]

Worum es geht ist klar. Ich möchte mittels Python ein gegebenes Input-File zusammenbauen, das natürlich aus beliebig vielen Includes (auch unterverzweigt!) bestehen kann. Ich habe schon verschiedene Sachen probiert, aber irgendwie komme ich auf keinen grünen Zweig.

Grüße
HH

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

femchen
Mitglied
wiss. MA


Sehen Sie sich das Profil von femchen an!   Senden Sie eine Private Message an femchen  Schreiben Sie einen Gästebucheintrag für femchen

Beiträge: 166
Registriert: 25.06.2009

erstellt am: 23. Jul. 2010 14:44    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für HerrHansen 10 Unities + Antwort hilfreich

Liste_1=[1,2,3]
Liste_2=[11,22,33]
Liste_3=[111,222,333]

Liste=reduce(list.__add__,[Liste_1,Liste_2,Liste_3])

oder wenn die Reihenfolge relevant ist:
Liste=reduce(list.__add__,[list(l) for l in zip(Liste_1,Liste_2,Liste_3)])

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

HerrHansen
Mitglied
Dipl.-Ing.


Sehen Sie sich das Profil von HerrHansen an!   Senden Sie eine Private Message an HerrHansen  Schreiben Sie einen Gästebucheintrag für HerrHansen

Beiträge: 257
Registriert: 03.12.2005

Abaqus/CAE 6.3 bis 6.12

erstellt am: 23. Jul. 2010 16:19    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo femchen,

ich stehe scheinbar auf dem Schlauch, weil ich nicht so richtig sehe, wie ich deinen Tipp auf mein Problem anwenden kann.
An die Stellen, wo in den Listen irgendetwas mit "include" auftaucht, soll statt "include" der entsprechende Inhalt der referenzierten Liste eingesetzt werden.

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

femchen
Mitglied
wiss. MA


Sehen Sie sich das Profil von femchen an!   Senden Sie eine Private Message an femchen  Schreiben Sie einen Gästebucheintrag für femchen

Beiträge: 166
Registriert: 25.06.2009

erstellt am: 24. Jul. 2010 23:46    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für HerrHansen 10 Unities + Antwort hilfreich

Meinst Du so etwas:

Liste_3=[111,222,333]
Liste_2=[11,Liste_3,22,Liste_3,33]
Liste_1=[1,Liste_2,2,3]

print 'Liste_1', Liste_1

def platt(liste):
    L = []
    for l in liste:
        if isinstance(l,list):
            L.extend(platt(l))
        else:
            L.append(l)
    return L

print 'Liste ', platt(Liste_1)

Da gibt es unzählige Varianten zu: http://www.google.com/search?hl=&q=python+flatten+recursive+list&

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

HerrHansen
Mitglied
Dipl.-Ing.


Sehen Sie sich das Profil von HerrHansen an!   Senden Sie eine Private Message an HerrHansen  Schreiben Sie einen Gästebucheintrag für HerrHansen

Beiträge: 257
Registriert: 03.12.2005

Abaqus/CAE 6.3 bis 6.12

erstellt am: 26. Jul. 2010 08:25    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Super! Genau so etwas habe ich gesucht, vielen Dank!
Mir war gar nicht klar, dass das ein Standard-Problem im Python ist. Ich wusste auch nicht so richtig, was ich ins google eingeben soll ("nested list" etc.).

Us folgen.

Gruß
HH

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2023 CAD.de | Impressum | Datenschutz