| |
| Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für Autodesk Produkte |
Autor
|
Thema: defun in foreach erstellen (1181 mal gelesen)
|
GottesGeschenk Mitglied Bauingenieur
Beiträge: 229 Registriert: 23.02.2007 winxp pro sp3 / intel p4 3GHz / 2,5GB RAM / CAD 2011
|
erstellt am: 22. Feb. 2012 11:25 <-- editieren / zitieren --> Unities abgeben:
hallo miteinander ist es möglich in einer foreach schleife defun zu erzeugen? mit diesen zeilen komme ich nicht weit. (foreach item '(a b) (defun item () (princ) ) ) hat jemand einen gedankenstoß? vielen dank gruß theo Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
cadffm Moderator 良い精神
Beiträge: 21533 Registriert: 03.06.2002 Alles
|
erstellt am: 22. Feb. 2012 11:50 <-- editieren / zitieren --> Unities abgeben: Nur für GottesGeschenk
Schau dir Defun-Konstrukt nochmal an: (defun a () (alert "test")) das ist also nichts weiter als eine Liste mit den Inhalten: defun a nil Liste(mit dem Inhalt: alert und a) Eine List ebaut man mit LIST, und da steckt man dann rein was rein soll, zuletzt muß dann nur noch gesagt werden das er die Liste ausführen soll, dann kommt des Defun zum Einsatz welches die Funktion definiert. JA, meine Erklärungen sind schrott, aber ich komme damit zurecht (eval (list 'defun 'a '() (list 'alert "test"))) Und in der foreach Version ? Da mußt du noch einmal neu überlegen wo ein Ausdruck evaluiert werden soll und wo nicht, weil das Symbol a ja an dem symbol 'item' hängt Code: (foreach item '(a b c d) (eval ;ausführen (list 'defun item nil ; Liste erstellen mit DEFUN als Funktion (list 'alert (vl-princ-to-string item)) ; irgendwas soll in dem defun auch drinstecken 1 '(princ) ; irgendwas soll in dem defun auch drinstecken 2 );_list_ende );_ausführen_ende );_foreach_ende
------------------ CAD.de System-Angaben - CAD on demand - User:FAQ(Acad) Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
CADmium Moderator Maschinenbaukonstrukteur
Beiträge: 13508 Registriert: 30.11.2003 .
|
erstellt am: 22. Feb. 2012 11:54 <-- editieren / zitieren --> Unities abgeben: Nur für GottesGeschenk
|
GottesGeschenk Mitglied Bauingenieur
Beiträge: 229 Registriert: 23.02.2007 winxp pro sp3 / intel p4 3GHz / 2,5GB RAM / CAD 2011
|
erstellt am: 22. Feb. 2012 11:57 <-- editieren / zitieren --> Unities abgeben:
|
archtools Mitglied
Beiträge: 823 Registriert: 09.10.2004 Entwickler für AutoCAD, BricsCAD u.a., alle Systeme
|
erstellt am: 24. Feb. 2012 19:30 <-- editieren / zitieren --> Unities abgeben: Nur für GottesGeschenk
Zitat: Original erstellt von cadffm: Schau dir Defun-Konstrukt nochmal an: (defun a () (alert "test"))das ist also nichts weiter als eine Liste mit den Inhalten: defun a nil Liste(mit dem Inhalt: alert und a) Eine List ebaut man mit LIST, und da steckt man dann rein was rein soll
Das ist nur eingeschränkt richtig - falsche Erklärung, aber richtige Lösung :-). Eigentlich (jaja, lange ist's her) baut das DEFUN ja auch eine Liste, nur tut's das im VisualLisp nicht mehr. Dafür gibt's das alte DEFUN noch als DEFUN-Q. Der entscheidende Punkt ist vielmehr, dass sowohl DEFUN als auch DEFUN-Q so gestrickt sind, dass sie das erste Argument NICHT evaluieren, sondern dass sie es wie beispielsweise die Funktion SETQ gequoted übernehmen. Deshalb kann das (defun item ...) in der foreach-Schleife nix werden. Deine Lösung ist aber natürlich korrekt.
Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
archtools Mitglied
Beiträge: 823 Registriert: 09.10.2004 Entwickler für AutoCAD, BricsCAD u.a., alle Systeme
|
erstellt am: 24. Feb. 2012 21:43 <-- editieren / zitieren --> Unities abgeben: Nur für GottesGeschenk
Zitat: Original erstellt von GottesGeschenk: hallo miteinanderist es möglich in einer foreach schleife defun zu erzeugen? mit diesen zeilen komme ich nicht weit. (foreach item '(a b) (defun item () (princ) ) ) hat jemand einen gedankenstoß? vielen dank gruß theo
Das DEFUN evaluiert das erste Element nicht, weshalb das ITEM in Deiner Schleife nicht zu den Elementen der Liste '(a b) evaluiert. So geht's richtig: (foreach item '(a b) (set item (lambda (x) (* x x x))) ) Danach ergibt (a 5) korrekt 125.
Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
GottesGeschenk Mitglied Bauingenieur
Beiträge: 229 Registriert: 23.02.2007 winxp pro sp3 / intel p4 3GHz / 2,5GB RAM / CAD 2011
|
erstellt am: 26. Feb. 2012 13:07 <-- editieren / zitieren --> Unities abgeben:
|