In diesem Artikel werden hauptsächlich die Lese- und Schreibvorgänge von Dateien in Python sowie die Operationsmethode zum Lesen von Daten aus Dateien vorgestellt. Dieser Artikel stellt es Ihnen anhand einer Kombination aus Beispielen und Text ausführlich vor dazu. Weiter
Daten aus der Datei lesen
Die gesamte Datei lesen
Hier wird davon ausgegangen, dass sich im aktuellen Verzeichnis eine Textdatei mit dem Namen „pi_digits.txt“ befindet. Die darin enthaltenen Daten lauten wie folgt:
3.1415926535
8979323846
2643383279
with open('pi_digits.txt') as f: # 默认模式为‘r',只读模式 contents = f.read() # 读取文件全部内容 print contents # 输出时在最后会多出一行(read()函数到达文件末会返回一个空字符,显示出空字符就是一个空行) print '------------' print contents.rstrip() # rstrip()函数用于删除字符串末的空白
3.1415926535
8979323846
2643383279
--- ----- ----
3.1415926535
8979323846
2643383279
Zeile für Zeile lesen
kann in einer Schleife ausgeführt werden. Um Daten Zeile für Zeile zu lesen:
with open('pi_digits.txt') as f: for line1 in f: print line1 # 每行末尾会有一个换行符 print '------------' for line2 in f: print line2.rstrip() # 此时文件已经读完,line2指向文本末尾,因此不会有输出
3.1415926535
8979323846
2643383279
-----------------------------------
Beim Lesen einer Datei entspricht dies Wenn Sie einen Zeiger haben, der die Leseposition aufzeichnet, an der die Daten gelesen werden, lesen Sie unabhängig davon, wohin der Zeiger zeigt, wenn Sie mit dem Lesen von Daten fortfahren, von dieser Position aus weiter, sodass die Ausgabe in der zweiten Schleife im obigen Code leer ist. Ändern Sie den obigen Code leicht wie folgt:
with open('pi_digits.txt') as f: for line1 in f: print line1 print '------------' with open('pi_digits.txt') as f: # 需要重新打开文本进行读取 for line2 in f: print line2.rstrip() # 删除字符串末尾的空白
3.1415926535
8979323846
2643383279
------------
3.1415926535
8979323846
2643383279
Der obige Code entspricht dem Lesen für Beim ersten Mal schließen Sie dann die Datei und öffnen sie erneut zum Lesen. Sie können die Funktion readline() auch verwenden, um Daten Zeile für Zeile zu lesen, wie folgt:
with open('pi_digits.txt') as f: # readline()每一次读取一行数据,并指向该行末尾 line1 = f.readline() # 读取第一行数据(此时已经指向第一行末尾) line2 = f.readline() # 从上一次读取末尾开始读取(第二行) print line1.rstrip() print line2.rstrip()
3.1415926535
8979323846
Manchmal möchten wir alle Daten auf einmal lesen und für nachfolgende Operationen separat speichern. Dies kann natürlich mit der obigen Schleife erreicht werden, aber Python bietet eine einfachere Methode readlines(). :
with open('pi_digits.txt') as f: lines = f.readlines() # 读取文本中所有内容,并保存在一个列表中,列表中每一个元素对应一行数据 print lines # 每一行数据都包含了换行符 print '------------' for line in lines: print line.rstrip() print '------------' pi_str = '' # 初始化为空字符 for line in lines: pi_str += line.rstrip() #字符串连接 print pi_str
['3.1415926535n', '8979323846n', '2643383279n']
---- -- -----
3.1415926535
8979323846
2643383279
------------
3.141592653589793238462643383279
Daten in Datei schreiben
Es gibt verschiedene Modi zum Schreiben von Daten. Die am häufigsten verwendeten sind w' und 'a', was bedeutet, dass die Originaldaten gelöscht werden Schreiben und Neuschreiben der Daten:
filename = 'write_data.txt' with open(filename,'w') as f: # 如果filename不存在会自动创建, 'w'表示写数据,写之前会清空文件中的原有数据! f.write("I am Meringue.\n") f.write("I am now studying in NJTECH.\n")
Zu diesem Zeitpunkt wird eine Textdatei von „write_data.txt“ erstellt. wird unter dem aktuellen Pfad erstellt und schreibt Daten wie folgt in die Datei:
Ich bin Meringue.
Ich studiere jetzt in NJTECH.
Die Folgendes fügt der Datei weiterhin neue Daten hinzu:
with open(filename,'a') as f: # 'a'表示append,即在原来文件内容后继续写数据(不清楚原有数据) f.write("I major in Machine learning and Computer vision.\n")
Der Inhalt der Datei ist derzeit:
Ich bin Meringue.
Ich studiere jetzt an der NJTECH.
Mein Hauptfach ist maschinelles Lernen und Computer Vision.
Verwandte Empfehlungen:
In Python implementierte Diagramme mit matplotlib Beispiele für Lese- und Schneidefunktionen
Das obige ist der detaillierte Inhalt vonLese- und Schreibvorgänge von Dateien in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!