Python实现备份文件实例
本文实例讲述了Python实现备份文件的方法,是一个非常实用的技巧。分享给大家供大家参考。具体方法如下:
该实例主要实现读取一个任务文件, 根据指定的任务参数自动备份.
任务文件的格式: (注意,分号后面注释是不支持的)
[task] ; 一项任务开始 dir=h:/Project ; 指定备份的目录 recusive=1 ; 是否递归子目录 suffix=h|cpp|hpp|c|user|filters|vcxproj|sln|css|gif|html|bmp|png|lib|dsw|dsp|htm|html|ico|ini|jpg|rc|vssscc ; 指定备份的扩展名 exclude=0 ; 指定是备份上面的参数指定的扩展名还是排除指定的扩展名 zip=Project.zip ; 备份后的文件路径名
python代码如下:
# -*- coding: utf-8 -*- import sys import os import zipfile class Task: #dir str directory #bsub BOOL include subdirectory #sfx str postsuffix ,sepeated by '|' #ecld BOOL include or execlude the postsuffix sfx def __init__(self,dir,bsub,sfx,ecld,zip): self.dir = dir self.bsub = bsub self.suffix = sfx.split("|") self.exclude = ecld self.zip = zip @staticmethod def isfilter(sfx,sfxs,bexcld): bFound = False for e in sfxs: if e == sfx: bFound = True break if bexcld: return not bFound; else: return bFound; class QBackup: '''备份指定目录下具备指定扩展名的文件''' def __init__(self): self._list = [] def __del__(self): pass #tfile 任务文件 def ReadTask(self,tfile): dir = "" bsub = False sfx = "" becld = False zip = "" try: f = open(tfile,'r') while True: line = f.readline() if len(line) == 0: break; line = line.strip(" ") if "[Task]/n".lower() == line.lower(): # 读取接下来的4行 iline = 1 while iline <= 5: line = f.readline() line = line.strip(" /t/n") # 去除前后的空白符 idx = line.find("=") if -1 == idx: break; atti = line[0:idx] value = line[idx+1:] print(value) if "dir" == atti: dir = value elif "recusive" == atti: bsub = bool(int(value)) elif "suffix" == atti: sufix = value elif "exclude" == atti: becld = bool(int(value)) elif "zip" == atti: zip = value else: break iline += 1 else: t = Task(dir,bsub,sufix,becld,zip) self._list.append(t) except: return False return True def DoBackup(self): for e in self._list: try: zip = zipfile.ZipFile(e.zip,'w',zipfile.ZIP_DEFLATED) self.ZipDir(zip,e.dir,e.bsub,e.suffix,e.exclude) zip.close() except: print("exception raised!") return False return True def ZipDir(self,zip,dir,bsub,sfxs,ecld): subdir = "" path = "" if os.path.isdir(dir): paths = os.listdir(dir) #备份本目录 print("ZipDir: ",dir) for e in paths: path = dir + "/" + e ext = os.path.splitext(e)[1][1:] if os.path.isfile(path) and Task.isfilter(ext,sfxs,ecld): print ("ZipFile: ",path) zip.write(path) #清理子目录 if bsub: for e in paths: subdir = dir + "/" + e self.ZipDir(zip,subdir,bsub,sfxs,ecld) def PrintTask(self): for e in self._list: print (e.dir,e.bsub,e.suffix,e.exclude,e.zip) if '__main__' == __name__: c = QBackup() c.ReadTask("bkup.txt") c.DoBackup()
希望本文所述对大家Python程序设计的学习有所帮助。

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.

Eine Anwendung, die XML direkt in PDF konvertiert, kann nicht gefunden werden, da es sich um zwei grundlegend unterschiedliche Formate handelt. XML wird zum Speichern von Daten verwendet, während PDF zur Anzeige von Dokumenten verwendet wird. Um die Transformation abzuschließen, können Sie Programmiersprachen und Bibliotheken wie Python und ReportLab verwenden, um XML -Daten zu analysieren und PDF -Dokumente zu generieren.

Um XML -Bilder zu konvertieren, müssen Sie zuerst die XML -Datenstruktur ermitteln, dann eine geeignete grafische Bibliothek (z. B. Pythons Matplotlib) und eine Methode auswählen, eine Visualisierungsstrategie basierend auf der Datenstruktur auswählen, das Datenvolumen und das Bildformat, die Batch -Verarbeitung ausführen oder effiziente Bibliotheken verwenden und schließlich als PNG, JPEG oder SVG nach den Bedürfnissen speichern.

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.

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.
