


Dieser Artikel hilft Ihnen, das Lesen und Schreiben von Python-Dateien zu verstehen
1. Was ist eine Datei?
Eine Datei soll etwas Speicherplatz speichern, sodass sie bei der nächsten Programmausführung direkt verwendet werden kann, ohne dass eine neue Kopie erstellt werden muss, was Zeit und Aufwand spart.
2. Wie öffne ich die Datei?
Python verfügt über eine integrierte open()-Methode, die Dateien lesen und schreiben kann.
Die Verwendung der open()-Methode zum Bedienen einer Datei ist, als würde man einen Elefanten in den Kühlschrank stopfen. Sie kann in drei Schritte unterteilt werden: Der eine besteht darin, die Datei zu öffnen, der andere darin, die Datei zu bedienen, und der dritte darin um die Datei zu schließen.
open-Syntax
Der Rückgabewert der open()-Methode ist ein Dateiobjekt, das einer Variablen (Dateihandle) zugewiesen werden kann.
Das grundlegende Syntaxformat ist:
f = open(filename, mode)
Hinweis:
In Python können alle Objekte mit Lese- und Schreibmethoden als Dateitypen klassifiziert werden. Alle Dateitypobjekte können mit der open-Methode geöffnet und mit der close-Methode beendet werden.
Dateiname: Ein Zeichenfolgenwert, der den Namen der Datei enthält, auf die Sie zugreifen möchten, normalerweise ein Dateipfad.
Modus: Es gibt viele Modi zum Öffnen von Dateien, der Standard ist der schreibgeschützte Modus r.
Beispiel:
# 打开一个文件 f = open("1.txt", "w") f.write("Python 是一种非常好的语言。\nPython!!\n") # 关闭打开的文件 f.close()
Laufendes Ergebnis:
Schreiben in einer 1.txt-Datei Python ist eine sehr gute Sprache. Python.
3. Zugriffsmodus
Verwenden Sie eine Tabelle, um die häufig verwendeten Lese- und Schreibmodi von Python zu verstehen
Zugriffsmodus | Beschreibung |
---|---|
r | . Öffnen die Datei im schreibgeschützten Modus. Der Dateizeiger wird am Anfang der Datei platziert. (Standardmodus). |
w | Öffnen Sie eine Datei nur zum Schreiben. Wenn die Datei bereits vorhanden ist, wird sie überschrieben. Wenn die Datei nicht vorhanden ist, erstellen Sie eine neue Datei. |
a | Öffnen Sie eine Datei zum Anhängen. Wenn die Datei bereits vorhanden ist, wird der Dateizeiger am Ende der Datei platziert. Mit anderen Worten: Neue Inhalte werden nach bestehenden Inhalten geschrieben. Wenn die Datei nicht vorhanden ist, erstellen Sie eine neue Datei zum Schreiben. |
rb | Öffnen Sie eine Datei im Binärformat zum schreibgeschützten Lesen. Der Dateizeiger wird am Anfang der Datei platziert. Dies ist der Standardmodus. |
wb | Öffnen Sie eine Datei im Binärformat nur zum Schreiben. Wenn die Datei bereits vorhanden ist, wird sie überschrieben. Wenn die Datei nicht vorhanden ist, erstellen Sie eine neue Datei. |
ab | Öffnen Sie eine Datei im Binärformat zum Anhängen. Wenn die Datei bereits vorhanden ist, wird der Dateizeiger am Ende der Datei platziert. Mit anderen Worten: Neue Inhalte werden nach bestehenden Inhalten geschrieben. Wenn die Datei nicht vorhanden ist, erstellen Sie eine neue Datei zum Schreiben. |
r+ | Öffnen Sie eine Datei zum Lesen und Schreiben. Der Dateizeiger wird am Anfang der Datei platziert. |
w+ | Öffnen Sie eine Datei zum Lesen und Schreiben. Wenn die Datei bereits vorhanden ist, wird sie überschrieben.Wenn die Datei nicht vorhanden ist, erstellen Sie eine neue Datei. |
a+ | Öffnen Sie eine Datei zum Lesen und Schreiben. Wenn die Datei bereits vorhanden ist, wird der Dateizeiger am Ende der Datei platziert. Die Datei wird im Anhängemodus geöffnet. Wenn die Datei nicht existiert, wird eine neue Datei zum Lesen und Schreiben erstellt. |
rb+ | Öffnen Sie eine Datei im Binärformat zum Lesen und Schreiben. Der Dateizeiger wird am Anfang der Datei platziert. |
wb+ | Öffnen Sie eine Datei im Binärformat zum Lesen und Schreiben. Wenn die Datei bereits vorhanden ist, wird sie überschrieben. Wenn die Datei nicht vorhanden ist, erstellen Sie eine neue Datei. |
ab+ | Öffnen Sie eine Datei im Binärformat zum Anhängen. Wenn die Datei bereits vorhanden ist, wird der Dateizeiger am Ende der Datei platziert. Wenn die Datei nicht vorhanden ist, wird eine neue Datei zum Lesen und Schreiben erstellt. |
如果要读取非UTF-8编码的文件,需要给open()函数传入encoding参数。
例如,读取GBK编码的文件:
>>> f = open('gbk.txt', 'r', encoding='gbk') >>> f.read() 'GBK' #编码
遇到有些编码不规范的文件,可能会抛出UnicodeDecodeError
异常,这表示在文件中可能夹杂了一些非法编码的字符。遇到这种情况,可以提供errors参数,表示如果遇到编码错误后如何处理。
f = open('gbk.txt', 'r', encoding='gbk', errors='ignore')
四、 文件对象操作
用open方法打开一个文件,将返回一个文件对象。这个对象内置了很多操作方法。
下面打开了一个f文件对象(1.txt)。对文件对象进行相关的操作。
1. f.read(size)
读取一定大小的数据, 然后作为字符串或字节对象返回。size是一个可选的数字类型的参数,用于指定读取的数据量。当size被忽略了或者为负值,那么该文件的所有内容都将被读取并且返回。
f = open("1.txt", "r") str = f.read() print(str) f.close()
如果文件体积较大,请不要使用read()方法一次性读入内存,而是read(312)这种一点一点的读。
2. f.readline()
从文件中读取一行n内容。换行符为'\n'。如果返回一个空字符串,说明已经已经读取到最后一行。这种方法,通常是读一行,处理一行的情况下使用。
f = open("1.txt", "r") str = f.readline() print(str) f.close()
3. f.readlines()
将文件中所有的行,一行一行全部读入一个列表内,按顺序一个一个作为列表的元素,并返回这个列表。readlines方法会一次性将文件全部读入内存,所以也存在一定的弊端。但是它有个好处,每行都保存在列表里,可随意存取。
f = open("1.txt", "r") a = f.readlines() print(a) f.close()
4. 遍历文件
实际情况中,我们会将文件对象作为一个迭代器来使用。
# 打开一个文件 f = open("1.txt", "r") for line in f: print(line, end='') # 关闭打开的文件 f.close()
这个方法很简单, 不需要将文件一次性读出,但是同样没有提供一个很好的控制,与readline方法一样只能前进,不能回退。
几种不同的读取和遍历文件的方法比较:
如果文件很小,read()一次性读取最方便;
如果不能确定文件大小,反复调用read(size)比较保险;
如果是配置文件,调用readlines()最方便。普通情况,使用for循环更好,速度更快。
5. f.write()
使用write()可以完成向文件写入数据。
# 打开一个文件 f = open("/tmp/foo.txt", "w") f.write("Python 是一种非常好的语言。\n我喜欢Python!!\n") # 关闭打开的文件 f.close()
6. f.tell()
返回文件读写指针当前所处的位置,它是从文件开头开始算起的字节数。一定要注意了,是字节数,不是字符数。
7. f.seek()
如果要改变位置指针的位置, 可以使用f.seek(offset, from_what)
方法。seek()经常和tell()方法配合使用。
from_what的值,如果是0表示从文件开头计算,如果是1表示从文件读写指针的当前位置开始计算,2表示从文件的结尾开始计算,默认为0,例如:
offset:表示偏移量。
seek(x,0) :从起始位置即文件首行首字符开始移动 x 个字符。
seek(x,1) :表示从当前位置往后移动x个字符。
seek(-x,2):表示从文件的结尾往前移动x个字符。
例:
f = open("1.txt", "rb+") f.write(b"1232312adsfalafds") print(f.tell()) print(f.seek(5)) print(f.read(1)) print(f.seek(-3, 2))
print(f.read(1))
运行结果:
8. f.close()
关闭文件对象。当处理完一个文件后,调用f.close()来关闭文件并释放系统的资源。文件关闭后,如果尝试再次调用该文件对象,则会抛出异常。忘记调用close()的后果是数据可能只写了一部分到磁盘,剩下的丢失了,或者更糟糕的结果。
五、 with关键字
with关键字用于Python的上下文管理器机制。为了防止open这一类文件打开方法,在操作过程出现异常或错误,或者最后忘了执行close方法,文件非正常关闭等可能导致文件泄露、破坏的问题。
Python提供了with这个上下文管理器机制,保证文件会被正常关闭。不需要再写close语句。注意缩进。
with open('test.txt', 'w') as f: f.write('Hello, world!')
with支持同时打开多个文件(文件都是随机创建的):
with open('1') as obj1, open('2','w') as obj2: s=obj1.read() obj2.write(s)
六、总结
本文基于Python基础,使用Python语言。介绍了有关Python文件操作的知识点,从文件的基本概念入手 ,通过一个个小项目的演示,对常用的读写模式,文件对象操作方法,以及在实际应用中需要注意的问题,都做了详细的讲解。希望帮助你更好的学习Python。
Das obige ist der detaillierte Inhalt vonDieser Artikel hilft Ihnen, das Lesen und Schreiben von Python-Dateien zu verstehen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Die Geschwindigkeit der mobilen XML zu PDF hängt von den folgenden Faktoren ab: der Komplexität der XML -Struktur. Konvertierungsmethode für mobile Hardware-Konfiguration (Bibliothek, Algorithmus) -Codierungsoptimierungsmethoden (effiziente Bibliotheken, Optimierung von Algorithmen, Cache-Daten und Nutzung von Multi-Threading). Insgesamt gibt es keine absolute Antwort und es muss gemäß der spezifischen Situation optimiert werden.

Mit einer einzigen Anwendung ist es unmöglich, XML -zu -PDF -Konvertierung direkt auf Ihrem Telefon zu vervollständigen. Es ist erforderlich, Cloud -Dienste zu verwenden, die in zwei Schritten erreicht werden können: 1. XML in PDF in der Cloud, 2. Zugriff auf die konvertierte PDF -Datei auf dem Mobiltelefon konvertieren oder herunterladen.

Es gibt keine integrierte Summenfunktion in der C-Sprache, daher muss sie selbst geschrieben werden. Die Summe kann erreicht werden, indem das Array durchquert und Elemente akkumulieren: Schleifenversion: Die Summe wird für die Schleifen- und Arraylänge berechnet. Zeigerversion: Verwenden Sie Zeiger, um auf Array-Elemente zu verweisen, und eine effiziente Summierung wird durch Selbststillstandszeiger erzielt. Dynamisch Array -Array -Version zuweisen: Zuordnen Sie Arrays dynamisch und verwalten Sie selbst den Speicher selbst, um sicherzustellen, dass der zugewiesene Speicher befreit wird, um Speicherlecks zu verhindern.

Es gibt keine App, die alle XML -Dateien in PDFs umwandeln kann, da die XML -Struktur flexibel und vielfältig ist. Der Kern von XML zu PDF besteht darin, die Datenstruktur in ein Seitenlayout umzuwandeln, für das XML analysiert und PDF generiert werden muss. Zu den allgemeinen Methoden gehören das Parsen von XML mithilfe von Python -Bibliotheken wie ElementTree und das Generieren von PDFs unter Verwendung der ReportLab -Bibliothek. Für komplexe XML kann es erforderlich sein, XSLT -Transformationsstrukturen zu verwenden. Wenn Sie die Leistung optimieren, sollten Sie Multithread- oder Multiprozesse verwenden und die entsprechende Bibliothek auswählen.

XML kann mithilfe eines XSLT -Konverters oder einer Bildbibliothek in Bilder konvertiert werden. XSLT -Konverter: Verwenden Sie einen XSLT -Prozessor und Stylesheet, um XML in Bilder zu konvertieren. Bildbibliothek: Verwenden Sie Bibliotheken wie Pil oder Imagemagick, um Bilder aus XML -Daten zu erstellen, z. B. Zeichnen von Formen und Text.

XML -Formatierungs -Tools können Code nach Regeln eingeben, um die Lesbarkeit und das Verständnis zu verbessern. Achten Sie bei der Auswahl eines Tools auf die Anpassungsfunktionen, den Umgang mit besonderen Umständen, die Leistung und die Benutzerfreundlichkeit. Zu den häufig verwendeten Werkzeugtypen gehören Online-Tools, IDE-Plug-Ins und Befehlszeilen-Tools.

Konvertieren Sie XML in PDF mit hoher Qualität auf Ihrem Mobiltelefon müssen: XML in der Cloud analysieren und PDFs mithilfe einer serverlosen Computerplattform generieren. Wählen Sie eine effiziente Bibliothek für XML -Parser- und PDF -Generation. Fehler korrekt behandeln. Nutzen Sie die Cloud -Computing -Leistung voll, um schwere Aufgaben auf Ihrem Telefon zu vermeiden. Passen Sie die Komplexität gemäß den Anforderungen an, einschließlich der Verarbeitung komplexer XML-Strukturen, der Erzeugung von mehrseitigen PDFs und dem Hinzufügen von Bildern. Drucken Sie Protokollinformationen zum Debuggen. Optimieren Sie die Leistung, wählen Sie effiziente Parser- und PDF -Bibliotheken aus und können asynchrone Programmier- oder Vorverarbeitungs -XML -Daten verwenden. Gewährleisten Sie eine gute Codequalität und -wartbarkeit.

Das Konvertieren von XML in PDF direkt auf Android-Telefonen kann durch die integrierten Funktionen nicht erreicht werden. Sie müssen das Land in den folgenden Schritten speichern: XML -Daten in Formate konvertieren, die vom PDF -Generator (z. B. Text oder HTML) erkannt wurden. Konvertieren Sie HTML mithilfe von HTML -Generationsbibliotheken wie Flying Saucer in PDF.
