« Python : Fichiers de config » : différence entre les versions
Aucun résumé des modifications |
|||
| Ligne 92 : | Ligne 92 : | ||
print("Clients :\n", clients) | print("Clients :\n", clients) | ||
===Récupérer des booléens=== | |||
Vu que par défaut, tout est récupéré en str, on dispose d'une méthode pour récupérer les booléens. | |||
Avec le fichier de config: | |||
[Alerts] | |||
send_alerts = False | |||
On peut faire: | |||
print(config['Alerts'].getboolean('send_alerts')) | |||
Version du 9 juin 2019 à 10:28
Utiliser un fichier de config avec le module configparser
Ecrire un fichier de config
Les fichiers de configuration sont gérés par le module configparser. Une fois importer il est assez simple à utiliser : il fonctionne avec des sections et stocke des clef : valeur dans un fichier similaire aux .ini de chez Microsoft.
Nous allons commencer par créer un fichier de configuration de façon programmatique.
import configparser
config=configparser.ConfigParser() #Création de l'objet parseur
config['DEFAULT']={'Test': 'yes'} #config[section] = clef:valeur
#Plusieurs clef: valeurs dans une section
config['Section']={'clef1': 'valeur1', 'clef2': 'valeur2'}
#Encore des clefs valeurs
config['bitbucket.org']={}
config['bitbucket.org']['User'] = 'hg'
config['topsecret.server.com'] = {}
with open('maconfig.ini', 'w') as configfile:
config.write(configfile)
Ce qui nous donne le fichier suivant:
[DEFAULT] test = yes [Section] clef1 = valeur1 clef2 = valeur2 [bitbucket.org] user = hg [topsecret.server.com]
Lire le contenu du fichier et récupérer les valeurs
Maintenant que nous avons notre fichier de config, on peut récupérer ses valeurs et utiliser les variables. Attention, les variables récupérées ne sont pas typées mais stockées sous la forme de str.
>>> import configparser
>>> config=configparser.ConfigParser()
>>> config.sections()
[]
>>> config.read('maconfig.ini')
['maconfig.ini']
>>> config.sections()
['Section', 'bitbucket.org', 'topsecret.server.com']
>>> 'coucou.fr' in config
False
>>> config['DEFAULT']['test']
'yes'
>>> for key in config:
... print(key)
...
DEFAULT
Section
bitbucket.org
topsecret.server.com
>>> for key in config['DEFAULT']:
... print(key)
...
test
Cela n'as rien de très complexe. Il faut surtout noter que les clefs sont toujours en minuscules, et que la section DEFAULT stocke les valeurs par défaut pour toutes les autres sections.
Récupérer les clefs et les valeurs et les mettre dans un dictionnaire
La méthode au dessus n'est pas vraiment la meilleure pour récupérer nos valeurs : si je veux récupérer un nombre indéfini de clefs : valeurs et les mettre dans un dictionnaire, il y'a plus simple.
Avec le fichier de config suivant :
[Clients] cloudflare = 1.1.1.1
Je peux avoir un dictionnaire du type clients = {'CloudFlare' : '1.1.1.1'} comme ceci:
clients={}
config=configparser.ConfigParser() #Creating parser object
config.read('jumonitor.conf') #Reading the file (it is loaded in the parser itself)
#Getting the clients
print(config.items('Clients'))
for key, value in config.items('Clients'):
clients[key]=value
print("Clients :\n", clients)
Récupérer des booléens
Vu que par défaut, tout est récupéré en str, on dispose d'une méthode pour récupérer les booléens.
Avec le fichier de config:
[Alerts] send_alerts = False
On peut faire:
print(config['Alerts'].getboolean('send_alerts'))