Rheinwerk Computing < openbook >

 
Inhaltsverzeichnis
1 Einleitung
2 Die Programmiersprache Python
Teil I Einstieg in Python
3 Erste Schritte im interaktiven Modus
4 Der Weg zum ersten Programm
5 Kontrollstrukturen
6 Dateien
7 Das Laufzeitmodell
8 Funktionen, Methoden und Attribute
9 Informationsquellen zu Python
Teil II Datentypen
10 Das Nichts – NoneType
11 Operatoren
12 Numerische Datentypen
13 Sequenzielle Datentypen
14 Zuordnungen
15 Mengen
16 Collections
17 Datum und Zeit
18 Aufzählungstypen – Enum
Teil III Fortgeschrittene Programmiertechniken
19 Funktionen
20 Modularisierung
21 Objektorientierung
22 Ausnahmebehandlung
23 Iteratoren
24 Kontextobjekte
25 Manipulation von Funktionen und Methoden
Teil IV Die Standardbibliothek
26 Mathematik
27 Kryptografie
28 Reguläre Ausdrücke
29 Schnittstelle zu Betriebssystem und Laufzeitumgebung
30 Kommandozeilenparameter
31 Dateisystem
32 Parallele Programmierung
33 Datenspeicherung
34 Netzwerkkommunikation
35 Debugging und Qualitätssicherung
36 Dokumentation
Teil V Weiterführende Themen
37 Anbindung an andere Programmiersprachen
38 Distribution von Python-Projekten
39 Grafische Benutzeroberflächen
40 Python als serverseitige Programmiersprache im WWW – ein Einstieg in Django
41 Wissenschaftliches Rechnen
42 Insiderwissen
43 Von Python 2 nach Python 3
A Anhang
Stichwortverzeichnis

Download:
- Beispielprogramme, ca. 464 KB

Jetzt Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Python 3 von Johannes Ernesti, Peter Kaiser
Das umfassende Handbuch
Buch: Python 3

Python 3
Pfeil 21 Objektorientierung
Pfeil 21.1 Klassen
Pfeil 21.1.1 Definieren von Methoden
Pfeil 21.1.2 Der Konstruktor und die Erzeugung von Attributen
Pfeil 21.2 Vererbung
Pfeil 21.2.1 Technische Grundlagen
Pfeil 21.2.2 Die Klasse GirokontoMitTagesumsatz
Pfeil 21.2.3 Mögliche Erweiterungen der Klasse Konto
Pfeil 21.2.4 Ausblick
Pfeil 21.2.5 Mehrfachvererbung
Pfeil 21.3 Setter und Getter und Property Attributes
Pfeil 21.3.1 Setter und Getter
Pfeil 21.3.2 Property-Attribute
Pfeil 21.4 Klassenattribute und Klassenmethoden sowie statische Methoden
Pfeil 21.4.1 Statische Methoden
Pfeil 21.4.2 Klassenmethoden
Pfeil 21.4.3 Klassenattribute
Pfeil 21.5 Built-in Functions für Objektorientierung
Pfeil 21.5.1 Funktionen für die Verwaltung der Attribute einer Instanz
Pfeil 21.5.2 Funktionen für Informationen über die Klassenhierarchie
Pfeil 21.6 Objektphilosophie
Pfeil 21.7 Magic Methods und Magic Attributes
Pfeil 21.7.1 Allgemeine Magic Methods
Pfeil 21.7.2 Operatoren überladen
Pfeil 21.7.3 Datentypen emulieren
 
Zum Seitenanfang

21.5    Built-in Functions für Objektorientierung Zur vorigen ÜberschriftZur nächsten Überschrift

Tabelle 21.2 listet diejenigen Built-in Functions auf, die sich speziell auf Objekte und Klasse beziehen.

Name Beschreibung
getattr(object, name, [default]) Liefert den Wert des Attributs name von der Instanz object.
setattr(object, name, value) Setzt den Wert des Attributs name von der Instanz object auf den Wert value.
hasattr(object, name) Prüft, ob die Instanz object das Attribut name besitzt. Ist das Attribut vorhanden, wird True, ansonsten False zurückgegeben.
delattr(object, name) Entfernt das Attribut name von der Instanz object.
isinstance(object, classinfo) Prüft, ob die Instanz object eine Instanz der von classinfo beschriebenen Klasse(n) ist.
issubclass(class_, classinfo) Prüft, ob die Klasse class_ eine Tochterklasse der von classinfo beschriebenen Klasse(n) ist.

Tabelle 21.2    Built-in Functions für Objektorientierung

 
Zum Seitenanfang

21.5.1    Funktionen für die Verwaltung der Attribute einer Instanz Zur vorigen ÜberschriftZur nächsten Überschrift

Um die Attribute einer Instanz zu verwalten, verwenden Sie die Funktionen setattr, getattr und delattr. Dabei kann auf ein Attribut zugegriffen werden, indem der Name des Attributs als String übergeben wird.

getattr(object, name, [default])

Diese Funktion gibt das Attribut mit dem Namen name von der Instanz object zurück, sofern dieses Attribut existiert. Falls default übergeben wurde, wird der Wert von default zurückgegeben, wenn das Attribut name nicht vorhanden ist.

Das folgende Beispiel greift mittels getattr auf ein vorhandenes und ein nicht vorhandenes Attribut zu. Dabei ist der Aufruf getattr(a, "X") gleichbedeutend mit a.X.

>>> class A:
... def __init__(self):
... self.X = 42
>>> a = A()
>>> getattr(a, "X")
42
>>> getattr(a, "Y", 404)
404

Ist das Attribut nicht vorhanden und wird kein Wert für default übergeben, wirft getattr eine AttributeError-Exception.

>>> getattr(a, "Y")
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'A' object has no attribute 'Y'

setattr(object, name, value)

Diese Funktion setzt den Wert des Attributs name von der Instanz object auf den Wert value.

Das folgende Beispiel definiert eine Klasse, die zehn Attribute in einer Schleife anlegt.

>>> class B:
... def __init__(self):
... for i in range(10):
... setattr(self, "X{}".format(i), i)
>>> b = B()
>>> b.X3
3
>>> b.X8
8

Ein Aufruf der Form setattr(a, "X", wert) ist dabei äquivalent zu a.X = wert.

delattr(object, name)

Mit delattr können Attribute einer Instanz gezielt gelöscht werden. Wir betrachten erneut die Klasse B aus dem obigen Beispiel zu setattr:

>>> b = B()
>>> b.X4
4
>>> delattr(b, "X4")
>>> b.X4
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'B' object has no attribute 'X4'

Der Aufruf delattr(b, "X4") hat dieselbe Wirkung wie del b.X4.

 
Zum Seitenanfang

21.5.2    Funktionen für Informationen über die Klassenhierarchie Zur vorigen ÜberschriftZur nächsten Überschrift

In diesem Abschnitt gehen wir von folgendem Beispielprogramm aus:

class A:
pass
class B(A):
pass
class C(B):
pass
class D:
pass
a = A()
b = B()
c = C()
d = D()

isinstance(object, classinfo)

Diese Funktion prüft, ob object eine Instanz der Klasse(n) classinfo ist, und liefert dementsprechend entweder True oder False zurück. Dabei kann für den Parameter classinfo entweder eine einzelne Klasse oder ein Tupel mehrerer Klassen übergeben werden.

>>> isinstance(a, A)
True
>>> isinstance(a, (B,C))
False
>>> isinstance(a, (A,B,C))
True

Der Rückgabewert von isinstance ist auch dann True, wenn object die Instanz einer Klasse ist, die von einer der Klassen in classinfo erbt.

>>> isinstance(c, A)
True
>>> isinstance(c, (B,D))
True

issubclass(class_, classinfo)

Mit der Funktion issubclass kann geprüft werden, ob die Klasse[ 92 ](Der Unterstrich am Ende von class_ wurde deshalb eingefügt, damit der Parameter nicht mit dem Schlüsselwort class zur Definition einer Klasse kollidiert. ) class_ von einer der Klassen in classinfo abgeleitet wurde. Genau wie bei isinstance kann für classinfo entweder eine einzelne Klasse oder ein Tupel mehrerer Klassen übergeben werden.

>>> issubclass(B,A)
True
>>> issubclass(B,(D,A))
True
>>> issubclass(A,C)
False
>>> issubclass(D,(A,B,C))
False

 


Ihre Meinung

Wie hat Ihnen das Openbook gefallen? Wir freuen uns immer über Ihre Rückmeldung. Schreiben Sie uns gerne Ihr Feedback als E-Mail an kommunikation@rheinwerk-verlag.de.

<< zurück
 Zum Rheinwerk-Shop
Zum Rheinwerk-Shop: Python 3 Python 3
Jetzt Buch bestellen

 Buchempfehlungen
Zum Rheinwerk-Shop: Einstieg in Python
Einstieg in Python


Zum Rheinwerk-Shop: Python. Der Grundkurs
Python. Der Grundkurs


Zum Rheinwerk-Shop: Algorithmen mit Python
Algorithmen mit Python


Zum Rheinwerk-Shop: Objektorientierte Programmierung
Objektorientierte Programmierung


Zum Rheinwerk-Shop: Raspberry Pi. Das umfassende Handbuch
Raspberry Pi. Das umfassende Handbuch


Zum Rheinwerk-Shop: Roboter-Autos mit dem Raspberry Pi
Roboter-Autos mit dem Raspberry Pi


Zum Rheinwerk-Shop: Neuronale Netze programmieren mit Python
Neuronale Netze programmieren mit Python


 Lieferung
Versandkostenfrei bestellen in Deutschland, Österreich und der Schweiz
InfoInfo

 
 


Copyright © Rheinwerk Verlag GmbH 2020
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das Openbook denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt.
Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.

 
[Rheinwerk Computing]

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern