


Comment utiliser le module de package de compression zipfile en Python
Introduction
Le format de fichier ZIP est une norme d'archivage et de compression couramment utilisée. Le module zipfile
fournit des outils pour créer, lire, écrire, ajouter et lister des fichiers ZIPzipfile
模块提供了创建、读取、写入、添加及列出 ZIP 文件的工具
此模块目前不能处理分卷 ZIP 文件,支持解密 ZIP 归档中的加密文件,但是目前不能创建一个加密的文件。解密非常慢,因为它是使用原生 Python 而不是 C 实现的
压缩文件
class zipfile.ZipFile(file, mode='r', compression=ZIP_STORED, allowZip64=True, compresslevel=None, *, strict_timestamps=True)
:ZipFile 对象,compression指定压缩模式
ZipFile.write(filename, arcname=None, compress_type=None, compresslevel=None)
:写入压缩文件,filename为原文件名,arcname为存档文件名,compress_type指定压缩模式
压缩模式 | 含义 |
ZIP_STORED | 不压缩,默认值 |
ZIP_DEFLATED | 常用的 ZIP 压缩 |
ZIP_BZIP2 | BZIP2 压缩 |
ZIP_LZMA | LZMA 压缩 |
代码如下:
import random import zipfile with open('1.txt', mode='w') as f: for _ in range(1000): f.write(str(random.random()) + '\n') with zipfile.ZipFile('1.zip', mode='w', compression=zipfile.ZIP_DEFLATED) as zf: zf.write('1.txt') zf.write('1.txt', '2.txt', zipfile.ZIP_STORED) # 原文件名1.txt,存为2.txt,不压缩
效果
解压文件
ZipFile.namelist()
:返回按名称排序的文件列表
ZipFile.extract(member, path=None, pwd=None)
:解压文件到指定目录
import zipfile with zipfile.ZipFile('1.zip') as zf: for filename in zf.namelist(): zf.extract(filename, '.')
是否ZIP文件
调用 zipfile.is_zipfile(filename)
是一个有效的 ZIP 文件返回 True
,否则返回 False
,压根不存在返回 False
import zipfile for filename in ['1.txt', '1.zip', '2.zip']: print(filename, zipfile.is_zipfile(filename)) # 1.txt False # 1.zip True # 2.zip False
读取元数据
ZipFile.namelist()
:返回按名称排序的文件列表
ZipFile.getinfo(name)
:返回一个 ZipInfo对象
import zipfile with zipfile.ZipFile('1.zip', 'r') as zf: print(zf.namelist()) # 文件列表 for info in zf.infolist(): print(info) print(info.filename) # 文件名称 print(info.date_time) # 修改时间,可用datetime.datetime(*info.date_time) print(info.compress_type) # 压缩类型,值为zipfile.ZIP_STORED、ZIP_DEFLATED、ZIP_BZIP2、ZIP_LZMA print(info.comment) # 注释 print(info.extra) # 扩展字段数据 print(info.create_system) # 创建所用系统,0为Windows,3为Unix print(info.create_version) # 创建所用PKZIP版本 print(info.extract_version) # 提取所用PKZIP版本 print(info.flag_bits) # 标志位 print(info.volume) # 文件头的分卷号 print(info.compress_size) # 已压缩的数据大小 print(info.file_size) # 未压缩的数据大小 print()
从其他数据源压缩文件
ZipFile.writestr(zinfo_or_arcname, data, compress_type=None, compresslevel=None)
:将一个文件写入压缩文件
import random import zipfile data = ''.join([str(random.random()) + '\n' for i in range(1000)]) with zipfile.ZipFile('1.zip', mode='w', compression=zipfile.ZIP_DEFLATED) as zf: zf.writestr('1.txt', data)
写入ZipInfo
class zipfile.ZipInfo(filename='NoName', date_time=(1980, 1, 1, 0, 0, 0))
:压缩文件成员信息类
import time import random import zipfile data = ''.join([str(random.random()) + '\n' for i in range(1000)]) with zipfile.ZipFile('1.zip', mode='w', compression=zipfile.ZIP_DEFLATED) as zf: info = zipfile.ZipInfo('1.txt', date_time=time.localtime(time.time())) info.compress_type = zipfile.ZIP_DEFLATED info.comment = b'a comment' info.create_system = 0 zf.writestr(info, data)
效果
追加文件
把 ZipFile
的 mode
改为追加模式 a
import random import zipfile with open('2.txt', mode='w') as f: for _ in range(1000): f.write(str(random.random()) + '\n') with zipfile.ZipFile('1.zip', mode='a') as zf: zf.write('2.txt')
创建包含Python库的ZIP
class zipfile.PyZipFile(file, mode='r', compression=ZIP_STORED, allowZip64=True, optimize=-1)
class zipfile.ZipFile(file, mode='r', compression=ZIP_STORED,allowZip64=True, compresslevel=None, * , strict_timestamps=True)
: objet ZipFile, la compression spécifie le mode de compression🎜🎜ZipFile.write(filename, arcname=None, compress_type=None, compresslevel=None)
: Écrivez un fichier compressé, filename est le nom du fichier d'origine, arcname est le nom du fichier d'archive, compress_type spécifie le mode de compression🎜Signification | |
ZIP_STORED | Aucune compression, valeur par défaut |
ZIP_DEFLATED | Compression ZIP couramment utilisée |
ZIP_BZIP2 | Compression BZIP2 |
ZIP_LZMA | Compression LZMA |
import sys import zipfile with zipfile.PyZipFile('pyzipfile.zip', mode='w') as zf: zf.debug = 3 zf.writepy('.') for name in zf.namelist(): print(name) sys.path.insert(0, 'pyzipfile.zip') import zipfile_pyzipfile print('Imported from:', zipfile_pyzipfile.__file__)

ZipFile.namelist()
: renvoie une liste de fichiers triés par name🎜🎜ZipFile.extract (member, path=None, pwd=None)
: Décompressez le fichier dans le répertoire spécifié🎜rrreee🎜Si le fichier ZIP🎜🎜Appelez zipfile.is_zipfile(filename )
🎜🎜est un ZIP valide Le fichier renvoie True
, sinon il renvoie False
S'il n'existe pas, il renvoie False🎜rrreee🎜Lire les métadonnées🎜🎜<code>ZipFile.namelist( )
: renvoie une liste de fichiers triés par nom 🎜🎜ZipFile.getinfo(name)
: renvoie un objet ZipInfo 🎜 rrreee🎜Compresser les fichiers provenant d'autres sources de données🎜🎜ZipFile.writestr (zinfo_or_arcname, data, compress_type=None, compresslevel=None)
: Écrivez un fichier dans le fichier compressé🎜rrreee🎜Écrivez dans ZipInfo🎜🎜class zipfile.ZipInfo(filename='NoName', date_time=( 1980, 1, 1, 0, 0, 0)) : classe d'informations sur les membres du fichier compressé🎜rrreee🎜Effect🎜🎜
mode
de ZipFile
> pour ajouter le mode a
🎜rrreee🎜Créer un ZIP contenant la bibliothèque Python🎜🎜class zipfile.PyZipFile(file, mode='r', compression=ZIP_STORED,allowZip64=True,optimise=-1 )
: utilisé pour créer une classe ZIP contenant la bibliothèque Python 🎜🎜zipfile_pyzipfile.py🎜rrreeeCe qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

La clé du contrôle des plumes est de comprendre sa nature progressive. Le PS lui-même ne fournit pas la possibilité de contrôler directement la courbe de gradient, mais vous pouvez ajuster de manière flexible le rayon et la douceur du gradient par plusieurs plumes, des masques correspondants et des sélections fines pour obtenir un effet de transition naturel.

L'article présente le fonctionnement de la base de données MySQL. Tout d'abord, vous devez installer un client MySQL, tel que MySQLWorkBench ou le client de ligne de commande. 1. Utilisez la commande MySQL-UROot-P pour vous connecter au serveur et connecter avec le mot de passe du compte racine; 2. Utilisez Createdatabase pour créer une base de données et utilisez Sélectionner une base de données; 3. Utilisez CreateTable pour créer une table, définissez des champs et des types de données; 4. Utilisez InsertInto pour insérer des données, remettre en question les données, mettre à jour les données par mise à jour et supprimer les données par Supprimer. Ce n'est qu'en maîtrisant ces étapes, en apprenant à faire face à des problèmes courants et à l'optimisation des performances de la base de données que vous pouvez utiliser efficacement MySQL.

MySQL a une version communautaire gratuite et une version d'entreprise payante. La version communautaire peut être utilisée et modifiée gratuitement, mais le support est limité et convient aux applications avec des exigences de stabilité faibles et des capacités techniques solides. L'Enterprise Edition fournit une prise en charge commerciale complète pour les applications qui nécessitent une base de données stable, fiable et haute performance et disposées à payer pour le soutien. Les facteurs pris en compte lors du choix d'une version comprennent la criticité des applications, la budgétisation et les compétences techniques. Il n'y a pas d'option parfaite, seulement l'option la plus appropriée, et vous devez choisir soigneusement en fonction de la situation spécifique.

La plume PS est un effet flou du bord de l'image, qui est réalisé par la moyenne pondérée des pixels dans la zone de bord. Le réglage du rayon de la plume peut contrôler le degré de flou, et plus la valeur est grande, plus elle est floue. Le réglage flexible du rayon peut optimiser l'effet en fonction des images et des besoins. Par exemple, l'utilisation d'un rayon plus petit pour maintenir les détails lors du traitement des photos des caractères et l'utilisation d'un rayon plus grand pour créer une sensation brumeuse lorsque le traitement de l'art fonctionne. Cependant, il convient de noter que trop grand, le rayon peut facilement perdre des détails de bord, et trop petit, l'effet ne sera pas évident. L'effet de plumes est affecté par la résolution de l'image et doit être ajusté en fonction de la compréhension de l'image et de la saisie de l'effet.

Les plumes de PS peuvent entraîner une perte de détails d'image, une saturation des couleurs réduite et une augmentation du bruit. Pour réduire l'impact, il est recommandé d'utiliser un rayon de plumes plus petit, de copier la couche puis de plume, et de comparer soigneusement la qualité d'image avant et après les plumes. De plus, les plumes ne conviennent pas à tous les cas, et parfois les outils tels que les masques conviennent plus à la gestion des bords de l'image.

L'optimisation des performances MySQL doit commencer à partir de trois aspects: configuration d'installation, indexation et optimisation des requêtes, surveillance et réglage. 1. Après l'installation, vous devez ajuster le fichier my.cnf en fonction de la configuration du serveur, tel que le paramètre innodb_buffer_pool_size, et fermer query_cache_size; 2. Créez un index approprié pour éviter les index excessifs et optimiser les instructions de requête, telles que l'utilisation de la commande Explication pour analyser le plan d'exécution; 3. Utilisez le propre outil de surveillance de MySQL (ShowProcessList, Showstatus) pour surveiller la santé de la base de données, et sauvegarde régulièrement et organisez la base de données. Ce n'est qu'en optimisant en continu ces étapes que les performances de la base de données MySQL peuvent être améliorées.

Guide d'optimisation des performances de la base de données MySQL dans les applications à forte intensité de ressources, la base de données MySQL joue un rôle crucial et est responsable de la gestion des transactions massives. Cependant, à mesure que l'échelle de l'application se développe, les goulots d'étranglement des performances de la base de données deviennent souvent une contrainte. Cet article explorera une série de stratégies efficaces d'optimisation des performances MySQL pour garantir que votre application reste efficace et réactive dans des charges élevées. Nous combinerons des cas réels pour expliquer les technologies clés approfondies telles que l'indexation, l'optimisation des requêtes, la conception de la base de données et la mise en cache. 1. La conception de l'architecture de la base de données et l'architecture optimisée de la base de données sont la pierre angulaire de l'optimisation des performances MySQL. Voici quelques principes de base: sélectionner le bon type de données et sélectionner le plus petit type de données qui répond aux besoins peut non seulement économiser un espace de stockage, mais également améliorer la vitesse de traitement des données.

Raisons et solutions courantes pour l'échec de l'installation MySQL: 1. Nom d'utilisateur ou mot de passe incorrect, ou le service MySQL n'est pas démarré, vous devez vérifier le nom d'utilisateur et le mot de passe et démarrer le service; 2. Conflits portuaires, vous devez modifier le port d'écoute MySQL ou fermer le programme qui occupe le port 3306; 3. La bibliothèque de dépendances est manquante, vous devez utiliser le gestionnaire de package système pour installer la bibliothèque de dépendances nécessaires; 4. Autorisations insuffisantes, vous devez utiliser les droits de Sudo ou d'administrateur pour exécuter l'installateur; 5. Fichier de configuration incorrect, vous devez vérifier le fichier de configuration My.cnf pour vous assurer que la configuration est correcte. Ce n'est qu'en travaillant régulièrement et soigneusement que MySQL peut être installé en douceur.
