Data Processing in Python

Präsentation

Wir haben nun einige Erfahrung gesammelt, um mit Tabellenprogrammen Daten zu bearbeiten und darzustellen. Aber was, wenn wir mehr Daten haben, als Excel darstellen kann?

Wieviel ist viel? 1000?

Aufgabe 1

Finde heraus, bei wie vielen Zeilen Excel oder Google Sheets in die Knie gehen.

Grossen Datenmengen sind natürlich nur ein Grund, weshalb wir mit einem Programm Daten lesen und schreiben wollen. Andere Gründe: wir wollen Benutzerdaten lesen oder speichern können, den Programmzustand abspeichern (und beim Neustart wieder einlesen), etc.

Wie lesen wir Daten in einer Text-Datei?

# Opens a file for reading (and closes it again after the 'with').
with open('dateiname.txt', 'r') as infile:
    count = 0
    # Loops over all lines in the file
    for line in infile:
        count += 1
    print(count)
  • Wenn Dateien gelesen oder geschrieben werden, müssen sie beim Betriebssystem reserviert werden. Mit with wird sichergestellt, dass die Datei nicht offen bleibt sondern nach dem Lesevorgang wieder geschlossen wird.
  • Die Datei (hier 'dateiname.txt') muss sich im gleichen Ordner befinden wie die Python-Datei.
  • 'r' bedeutet read, dass die Textdatei nur gelesen und nicht verändert wird.

Aufgabe 2

Lade die Datei gemeinden.csv herunter und speichere sie im Ordner, wo du dein Python-Programm abspeicherst. Verwende obigen Python-Code, um herauszufinden, wieviel Zeilen die Datei hat .

Schreiben funktioniert ganz ähnlich wie lesen, aber als zweites Argument muss 'w' (für write) angegeben werden:

with open('dateiname.txt', 'w') as outfile:
    for i in range(10):
        line = "Zeile " + str(i) + "\n"
        outfile.write(line)

Beachte:

  • str() verwandelt die Zahl in einen Text.
  • '\n' ist der ASCII-Code für einen Zeilenumbruch.

Aufgabe 3

Beschreibe eine Datei mit einigen Zeilen. Es ist ungünstig, mehr als einige zehntausend Zeilen zu schreiben…

Die Datei gemeinden.csv ist im Comma-Separated-Values Format gespeichert: Die Daten sind ganz ähnlich gespeichert wie in einer Tabelle und können auch mit Excel und Sheets geöffnet werden. Jede Zeile entspricht einer Zeile der Tabelle; die Spalten sind meist mit Kommas voneinander getrennt. Manchmal werden aber auch Semikolons oder ein Tabulator (\t) als Trennzeichen verwendet.

Oft werden in der ersten Zeile die Namen der abgespeicherten Werte festgelegt:

Gemeinde,Kanton,Einwohner,Fläche
Aadorf,TG,9216,19.93
Aarau,AG,21726,12.36
...

Wollen wir eine Zeile in die einzelnen Werte aufspalten, müssen wir dafür ein paar String-Operationen kennen:

  • split(char) erzeugt aus einem String eine Liste von Werten, die mit dem angegebenen Trennzeichen abgetrennt sind:
    • "Aarau,AG,21726,12.36".split(',') erzeugt die Liste ["Aarau","AG","21726","12.36"]
  • strip() gibt den selben String zurück, aber ohne Leerschläge an beiden Enden.

Aufgabe 4

Wandle den Code aus Aufgabe 2 so ab, dass jeweils der Kanton auf der Konsole ausgegeben wird:

  • Jede Zeile wird mit values = line.split(',') aufgeteilt.
  • Mit print(values[1]) wird der Kanton (die zweite Spalte) ausgegeben.
  • Wieviele Gemeinden gibt es im Kanton Thurgau? Wieviele im Kanton Bern?

Lösung:

Alles, was wir aus der Textdatei lesen, ist… well, Text. Damit wir mit den Werten rechnen können, müssen wir die Strings umwandeln. Dazu verwenden wir die folgenden eingebauten Funktionen:

  • int(string) wandelt einen String in eine Ganzzahl (integer) um.
  • float(string) wandelt einen String in eine reelle Zahl (floating point number - Fliesskommazahl) um.

Allerdings funktioniert das nur, wenn der String auch wirklich eine Zahl darstellt. Sonst wird eine Exception geworfen; wir können sie mit try...except auffangen:

try:
    my_number = int("abc")  # may throw an exception
    print(my_number)        # only executes if the above was successful
except ValueError:
    pass                    # executed if an exception was thrown

Aufgabe 5

Benütze try...except um in deinem Code die Bevölkerung und die Fläche der Gemeinden auszulesen.

  • welche Spalten (Indices) gehören zu diesen Werten?
  • verwendest du int() oder float()?

Aufgabe 6

Schreibe Python-Code, um die folgenden Fragen zu beantworten:

  • Was ist die Gemeinde mit der kleinsten Bevölkerungszahl?
  • Welche Gemeinde hat die grösste Fläche?
  • Wieviele Einwohner hat die Schweiz?

Lösung:

Aufgabe 7

Erweitere den Code, um folgende Fragen zu beantworten:

  • Welches ist die Thurgauer Gemeinde mit den wenigsten Einwohnern?
  • Was ist die Gesamtfläche aller Tessiner Gemeinden?
  • Wieviele Gemeinden hat der Kanton Glarus?

Weiter mit Dictionaries.

  • gf_informatik/daten/processing.1685535188.txt.gz
  • Zuletzt geändert: 2023-05-31 12:13
  • von hof