Création d'une application pratique - Générateur de rapports
Dans cette dernière étape, nous allons créer une application plus pratique qui démontre comment utiliser la fonction print() avec la redirection de fichier pour générer un rapport formaté. Cet exemple montrera comment cette technique peut être appliquée dans des scénarios réels.
Construction d'un générateur de rapports de ventes
Créons un script qui génère un rapport de ventes basé sur des exemples de données :
- Créez un nouveau fichier nommé
sales_report_generator.py dans le répertoire /home/labex/project
- Ajoutez le code suivant au fichier :
import datetime
## Sample sales data (product, quantity, price)
sales_data = [
{"product": "Laptop", "quantity": 5, "price": 899.99},
{"product": "Mouse", "quantity": 10, "price": 24.99},
{"product": "Keyboard", "quantity": 7, "price": 49.99},
{"product": "Monitor", "quantity": 3, "price": 149.99},
{"product": "Headphones", "quantity": 12, "price": 79.99}
]
def generate_sales_report(filename):
"""Generate a formatted sales report and save it to a file."""
today = datetime.datetime.now().strftime("%Y-%m-%d")
with open(filename, "w") as report_file:
## Print the report header
print("=" * 60, file=report_file)
print(f"SALES REPORT - Generated on {today}", file=report_file)
print("=" * 60, file=report_file)
print("", file=report_file)
## Print the table header
print(f"{'Product':<15} {'Quantity':<10} {'Price ($)':<10} {'Total ($)':<10}", file=report_file)
print("-" * 50, file=report_file)
## Print sales data and calculate totals
grand_total = 0
total_items = 0
for item in sales_data:
product = item["product"]
quantity = item["quantity"]
price = item["price"]
total = quantity * price
print(f"{product:<15} {quantity:<10} {price:<10.2f} {total:<10.2f}", file=report_file)
grand_total += total
total_items += quantity
## Print the summary
print("-" * 50, file=report_file)
print(f"{'Total':<15} {total_items:<10} {'':<10} {grand_total:<10.2f}", file=report_file)
print("", file=report_file)
print("=" * 60, file=report_file)
print("End of Report", file=report_file)
## Generate the report
report_filename = "sales_report.txt"
generate_sales_report(report_filename)
print(f"Sales report has been generated: {report_filename}")
print("\nContents of the sales report:")
with open(report_filename, "r") as file:
print(file.read())
- Enregistrez le fichier et exécutez-le :
python3 sales_report_generator.py
Vous devriez voir une sortie qui inclut :
Sales report has been generated: sales_report.txt
Contents of the sales report:
============================================================
SALES REPORT - Generated on 2023-09-10
============================================================
Product Quantity Price ($) Total ($)
--------------------------------------------------
Laptop 5 899.99 4499.95
Mouse 10 24.99 249.90
Keyboard 7 49.99 349.93
Monitor 3 149.99 449.97
Headphones 12 79.99 959.88
--------------------------------------------------
Total 37 6509.63
============================================================
End of Report
Cet exemple démontre comment créer un rapport bien formaté en utilisant la fonction print() avec la redirection de fichier. Le rapport comprend des en-têtes, des données formatées dans une mise en page tabulaire et des informations récapitulatives.
Création d'un système de rotation de journaux dynamique
Créons un autre exemple qui démontre un système de rotation de journaux, qui crée un nouveau fichier journal à chaque exécution du script :
- Créez un nouveau fichier nommé
rotating_log.py dans le répertoire /home/labex/project
- Ajoutez le code suivant au fichier :
import datetime
import os
def create_log_file():
"""Create a new log file with a timestamp in the filename."""
timestamp = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")
log_dir = "logs"
## Create logs directory if it doesn't exist
if not os.path.exists(log_dir):
os.makedirs(log_dir)
return os.path.join(log_dir, f"log_{timestamp}.txt")
def log_event(log_file, event_type, message):
"""Log an event to the specified log file."""
timestamp = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
with open(log_file, "a") as f:
print(f"[{timestamp}] [{event_type.upper()}] {message}", file=f)
## Create a new log file
log_filename = create_log_file()
print(f"Created new log file: {log_filename}")
## Simulate some application events
log_event(log_filename, "info", "Application started")
log_event(log_filename, "info", "Initializing modules...")
log_event(log_filename, "warning", "Configuration file not found, using defaults")
log_event(log_filename, "info", "Processing data batch #1")
log_event(log_filename, "error", "Failed to connect to database server")
log_event(log_filename, "info", "Retrying connection in 5 seconds")
log_event(log_filename, "info", "Connection established")
log_event(log_filename, "info", "Application shutting down")
print("\nLog file contents:")
with open(log_filename, "r") as f:
print(f.read())
- Enregistrez le fichier et exécutez-le :
python3 rotating_log.py
Vous devriez voir une sortie similaire à :
Created new log file: logs/log_20230910_153045.txt
Log file contents:
[2023-09-10 15:30:45] [INFO] Application started
[2023-09-10 15:30:45] [INFO] Initializing modules...
[2023-09-10 15:30:45] [WARNING] Configuration file not found, using defaults
[2023-09-10 15:30:45] [INFO] Processing data batch #1
[2023-09-10 15:30:45] [ERROR] Failed to connect to database server
[2023-09-10 15:30:45] [INFO] Retrying connection in 5 seconds
[2023-09-10 15:30:45] [INFO] Connection established
[2023-09-10 15:30:45] [INFO] Application shutting down
Cet exemple démontre une application plus avancée de la sortie de fichier en Python. Chaque fois que le script s'exécute, il crée un nouveau fichier journal avec un horodatage dans le nom, ce qui facilite l'organisation et la gestion des journaux.
Ces exemples pratiques montrent comment la redirection de la sortie de la fonction print() vers des fichiers peut être utilisée pour créer des applications utiles comme des générateurs de rapports et des systèmes de journalisation. Les techniques que vous avez apprises dans ce laboratoire peuvent être appliquées à de nombreux scénarios réels où vous devez enregistrer la sortie du programme pour une référence ou une analyse ultérieure.