


Traitement d'image Python : la bibliothèque Pillow implémente l'annotation automatique du texte de retour à la ligne
Python est devenu le langage de programmation leader dans le domaine du traitement d'images avec ses riches bibliothèques open source. Pillow est l'une des bibliothèques de traitement d'images couramment utilisées. Elle est simple, facile à utiliser et dispose d'une documentation complète. Elle est souvent utilisée pour des opérations telles que la mise à l'échelle de l'image, le recadrage, le réglage de la luminosité et l'annotation.
Cependant, Pillow a un problème avec l'annotation du texte : lorsque le texte dépasse la largeur de la zone de texte, il ne s'enroulera pas automatiquement. La bibliothèque Pillow elle-même ne fournit pas cette fonction et nous devons écrire nous-mêmes l'implémentation logique.
Ce didacticiel montrera comment utiliser la bibliothèque Pillow pour ajouter une zone de texte de retour à la ligne en Python afin d'obtenir une annotation correcte du texte de l'image. L'effet final est le suivant :
L'image ci-dessus est une capture d'écran de mon profil Dev.to, nous l'utiliserons comme exemple pour expliquer. La zone de texte verte est l'annotation de texte que nous avons ajoutée.
Préparation
Ce tutoriel nécessite que vous ayez des connaissances de base en programmation Python, telles que les instructions conditionnelles (if, else), les boucles for, etc. Vous aurez également besoin des outils et logiciels suivants :
- Python3 : Interpréteur pour exécuter des scripts Python.
- Pillow : bibliothèque de traitement d'images Python.
- Éditeur de code : tel que Pycharm, VScode, etc.
Créer un nouveau projet
Suivez ces étapes pour créer un nouveau projet :
A. Créez un nouveau dossier à l'aide du terminal/ligne de commande :
mkdir image_annotation
B. Utilisez pip pour installer virtualenv (ignorez cette étape si vous l'avez déjà installé) :
pip install virtualenv
C. Basculez le répertoire de travail vers le dossier image_annotation :
cd image_annotation
D. Créer un nouvel environnement virtuel :
virtualenv env
E. Activer l'environnement virtuel (utiliser l'invite de commande pour Windows) :
Windows :
.\env\Scripts\activate
Linux/macOS :
source env/bin/activate
F. Utilisez pip pour installer la bibliothèque Pillow :
pip install pillow
Ouvrez le projet dans l'éditeur de code et créez un nouveau fichier Python nommé script.py
dans le dossier du projet.
Préparer l'image de base
L'image que vous souhaitez annoter est l'image de base. Ouvrez et préparez l'image à l'aide du module ImageDraw
de Pillow. Écrivez le code suivant dans le fichier script.py
:
from PIL import Image, ImageDraw, ImageFont image_file = "path_to_image" # 请替换为您的图片路径 # 打开图像 image = Image.open(image_file) # 初始化ImageDraw draw = ImageDraw.Draw(image)
Ajouter une annotation d'image
Pillow peut ajouter du texte brut et des zones de texte avec un remplissage en arrière-plan. Le texte peut être une seule ligne ou plusieurs lignes. Ce didacticiel explique comment ajouter une zone de texte multiligne.
La méthodeImageDraw.multiline_text()
peut ajouter plusieurs lignes de texte brut, mais pas de remplissage d'arrière-plan. La méthode ImageDraw.rectangle()
peut ajouter une zone de texte avec un remplissage en arrière-plan.
Ajoutez le code suivant dans le fichier script.py
:
mkdir image_annotation
Ce code définit le texte, la police et la largeur de la zone de texte. Les variables x
et y
représentent le point de départ du dessin, et end_x
et end_y
représentent les coordonnées du coin inférieur droit de la zone de texte. La largeur et la hauteur de la zone de texte sont respectivement de 200 et 50.
ImageDraw.rectangle()
et ImageDraw.multiline_text()
sont utilisées respectivement pour dessiner des zones de texte et du texte multiligne. La méthode image.show()
est utilisée pour afficher l'image traitée. Vous pouvez enregistrer l'image en utilisant image.save("new_image.png")
. Les résultats sont les suivants :
Il y a toujours un problème avec l'annotation dans l'image ci-dessus, et le texte multiligne ne s'enroule pas automatiquement. La section suivante explique comment résoudre ce problème.
Réaliser un retour à la ligne automatique
Le caractère de saut de ligne n
est utilisé pour spécifier la position du saut de ligne. Dans l'exemple précédent, le contenu après le caractère de nouvelle ligne n
sera renvoyé à la ligne. Mais dans les applications pratiques, la longueur du texte est généralement dynamique et il est difficile de déterminer la position du caractère de nouvelle ligne.
du module ImageDraw
de .textlength()
Pillow peut calculer la longueur du texte et la comparer avec la largeur de la zone de texte pour déterminer la position du saut de ligne.
Créez une nouvelle fonction nommée script.py
en haut du fichier wrap_text()
(après l'instruction d'importation), contenant la logique de retour à la ligne :
pip install virtualenv
Ajoutez le code suivant après les variables text
, font
, max_width
:
cd image_annotation
Remplacez la méthode draw.multiline_text()
par le code suivant :
virtualenv env
Supprimez les nouvelles lignes du texte n
et exécutez le code :
.\env\Scripts\activate
Le résultat affiché montre que le texte dépasse toujours la hauteur de la zone de texte. Tandis que le texte s'ajuste automatiquement à la largeur de la zone de texte, la hauteur de la zone de texte est fixe, provoquant un débordement du texte.
Définir la hauteur de la zone de texte dynamique
La hauteur de la zone de texte dynamique est déterminée en fonction du nombre de lignes de texte. La première étape consiste à changer la variable end_y
de la zone de texte en une valeur dynamique :
source env/bin/activate
Cette formule a été trouvée après de nombreuses expériences et elle semble être la meilleure solution pour obtenir une hauteur de zone de texte dynamique dans ce cas d'utilisation. wrapped_lines
La liste contient toutes les lignes à ajouter à la zone de texte, la longueur de la liste est donc égale au nombre total de lignes de la zone de texte.
Les résultats sont les suivants :
Vous devrez peut-être multiplier le nombre total de lignes par différentes valeurs pour obtenir la solution parfaite pour votre cas d'utilisation.
Ajouter un remplissage de texte
Le texte est trop proche du bord de la zone de texte, ce qui affecte la lisibilité et le style. Vous pouvez résoudre ce problème en ajoutant un remplissage à l'intérieur de la zone de texte. Ajoutez une nouvelle variable script.py
dans le fichier padding
et modifiez la taille de la zone de texte :
pip install pillow
Ce code permet un espacement entre le texte et les bords de la zone de texte.
Ajouter un pointeur
Le pointeur peut facilement indiquer la partie de l'image à laquelle l'annotation/l'étiquette fait référence. Le pointeur doit être avant l'étiquette. Cela signifie que le pointeur sera dessiné à la position actuelle de la zone de texte et que la zone de texte se déplacera vers la droite.
Par conséquent, l'axe des x de la zone de texte sera associé à la nouvelle variable box_x
. Ce changement doit également être reflété dans d'autres variables en utilisant l'axe X de la zone de texte. Voici le code mis à jour :
mkdir image_annotation
Dans le code ci-dessus, la méthode ImageDraw.circle()
(où 10 est le rayon) est utilisée pour dessiner le pointeur au point spécifié. box_x
La variable est la nouvelle valeur de l'axe des x de la zone de texte.
Code complet
Ce qui suit est le code complet du script.py
fichier :
pip install virtualenv
Conclusion
Le traitement des images n'est pas toujours aussi difficile qu'il y paraît. Bien que certaines bibliothèques de traitement d'images ne puissent pas résoudre directement votre problème avec leurs modules, vous pouvez utiliser les modules existants pour implémenter une solution spécifique à votre cas d'utilisation. C'est la beauté du codage : être capable de résoudre des problèmes avec des solutions personnalisées et spécifiques.
Dans ce didacticiel, vous avez appris à utiliser la bibliothèque Pillow de Python pour annoter des images, ajouter des zones de texte multilignes renvoyées à la ligne, et bien plus encore. Vous avez également appris à écrire des formules mathématiques qui peuvent vous aider dans le traitement des images.
Veuillez vous référer à la documentation Pillow pour plus de détails sur les modules utilisés.
Ce 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!

Les raisons pour lesquelles les scripts Python ne peuvent pas fonctionner sur les systèmes UNIX incluent: 1) des autorisations insuffisantes, en utilisant Chmod xyour_script.py pour accorder des autorisations d'exécution; 2) Ligne Shebang incorrecte ou manquante, vous devez utiliser #! / Usr / bin / enwpython; 3) Paramètres de variables d'environnement incorrectes, vous pouvez imprimer OS.environ Debogging; 4) En utilisant la mauvaise version Python, vous pouvez spécifier la version sur la ligne Shebang ou la ligne de commande; 5) Problèmes de dépendance, en utilisant un environnement virtuel pour isoler les dépendances; 6) Erreurs de syntaxe, utilisez python-mpy_compileyour_script.py pour détecter.

L'utilisation de tableaux Python est plus adapté au traitement de grandes quantités de données numériques que les listes. 1) Les tableaux économisent plus de mémoire, 2) les tableaux sont plus rapides pour fonctionner par des valeurs numériques, 3) la cohérence de type de force des tableaux, 4) Les tableaux sont compatibles avec les tableaux C, mais ne sont pas aussi flexibles et pratiques que les listes.

Listes sont une meilleure ancêtres et des datatatates de mix

NumpyManagesMemoryForLargeArraySEfficientlyUsingViews, Copies andMemory-MapyPiles.1) Vues Allowcing withoutcopy

ListSinpythondonoTequireImporttingAmodule, tandis que les listes de la part de la variation de la daymoduleeeedanimport.1)

PythonlistScanstoreanyDatatype, ArrayModulearRaySstoreOneType, et NumpyArraysArnumericalComptations.1) ListesaSaSatilebutlessmemory-Efficient.2) NumpyArraySareMory-EfficientForHomoGeneousData.3)

Lorsque vous vous assumez de la valeur de la valeur de la datyypie de la datyylethonarray.

PythonlistSaReparmentofthestandardLibrary, tandis que les coloccules de colocède, tandis que les colocculations pour la base de la Parlementaire, des coloments de forage polyvalent, tandis que la fonctionnalité de la fonctionnalité nettement adressée.


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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Adaptateur de serveur SAP NetWeaver pour Eclipse
Intégrez Eclipse au serveur d'applications SAP NetWeaver.

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !

MantisBT
Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.
