begin process at 2010 03 18 17:56:26
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Application complète

 > CARNET D'ADRESSE

CARNET D'ADRESSE


 Information sur la source

Note :
9 / 10 - par 2 personnes
9,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Application complète Classé sous :aéra, group, wxpython, liste, contacte Niveau :Débutant Date de création :28/05/2007 Date de mise à jour :01/06/2007 09:17:38 Vu / téléchargé :4 279 / 283

Auteur : aera group

Ecrire un message privé
Commentaire sur cette source (14)
Ajouter un commentaire et/ou une note

 Description

Cliquez pour voir la capture en taille normale
Sur python france il y a plusieurs sources qui ont pour but de liter des contactes. Ce programme à une interface graphique faite avec WxPython. On peut entrer un nombre illimité de contacte, les modifier, les imprimer, protégé le document par un mot de passe (attention, pas de cryptage), ... Il y a encore quelles que fonctions à ajouté (une version 2.0 est déja à l'étude !), mais globalement tous fonctionne correctement. Le programme crée des fichiers *.list que vous pouvez ouvrir depuis le menu "fichier, ouvrir". Dans une prochaine version, j'ajouterais de l'aide.

Source

  • import wx
  • import os
  • import wx.lib.printout as printout
  • import wx.lib.hyperlink as hl
  • #############
  • provider = wx.SimpleHelpProvider()
  • wx.HelpProvider_Set(provider)
  • #########################################
  • version=u"1.1"
  • #########################################
  • class Propriete_document(wx.Dialog):
  • def __init__(
  • self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition,
  • style=wx.DEFAULT_DIALOG_STYLE
  • ):
  • self.parent=parent
  • pre = wx.PreDialog()
  • pre.Create(parent, ID, title, pos, size, style)
  • self.PostCreate(pre)
  • sizer = wx.BoxSizer(wx.VERTICAL)
  • label = wx.StaticText(self, -1, u"Propriétée du document\nDans les prochaine version, plus d'indormarion seront répertorié")
  • sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l1 = wx.StaticText(self, -1, u"Nom du document")
  • box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e1 = wx.TextCtrl(self, -1, self.parent.titre, size=(180,-1))
  • box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • b = wx.Button(self, -1, u"OK")
  • b.SetDefault()
  • sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • self.Bind(wx.EVT_BUTTON, self.valide, b)
  • btnsizer = wx.StdDialogButtonSizer()
  • if wx.Platform != u"__WXMSW__":
  • btn = wx.ContextHelpButton(self)
  • self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • btn = wx.Button(self, wx.ID_CANCEL,u"Annuler")
  • sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)
  • self.SetSizer(sizer)
  • sizer.Fit(self)
  • def valide(self,evt):
  • if self.e1.GetValue()=="":
  • dia=wx.MessageDialog(self, u"Le champs d'entréé est vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • self.Destroy()
  • self.parent.titre= self.e1.GetValue()
  • self.parent.SetTitle(u"Carnet d'adresse - " + self.e1.GetValue() +u" [" + self.parent.chemin +u"]")
  • class Accee_document(wx.Dialog):
  • def __init__(
  • self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition,
  • style=wx.DEFAULT_DIALOG_STYLE
  • ):
  • self.parent=parent
  • pre = wx.PreDialog()
  • pre.Create(parent, ID, title, pos, size, style)
  • self.PostCreate(pre)
  • sizer = wx.BoxSizer(wx.VERTICAL)
  • label = wx.StaticText(self, -1, u"Ce document est protégé par un mot de passe\nEn cas de perte, il sera impossible d'ouvrir la liste")
  • sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l1 = wx.StaticText(self, -1, u"Mot de passe")
  • box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e1 = wx.TextCtrl(self, -1, "",style=wx.TE_PASSWORD, size=(180,-1))
  • box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • b = wx.Button(self, -1, u"Valider")
  • b.SetDefault()
  • sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • self.Bind(wx.EVT_BUTTON, self.valide, b)
  • btnsizer = wx.StdDialogButtonSizer()
  • if wx.Platform != u"__WXMSW__":
  • btn = wx.ContextHelpButton(self)
  • self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • btn = wx.Button(self, wx.ID_CANCEL,u"Annuler")
  • sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)
  • self.SetSizer(sizer)
  • sizer.Fit(self)
  • def valide(self,evt):
  • if self.e1.GetValue()==u"":
  • dia=wx.MessageDialog(self, u"Le champs d'entréé est vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • self.Destroy()
  • self.valeur= self.e1.GetValue().encode("windows-1252")
  • class About(wx.Dialog):
  • def __init__(
  • self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition,
  • style=wx.DEFAULT_DIALOG_STYLE
  • ):
  • global version
  • pre = wx.PreDialog()
  • pre.Create(parent, ID, title, pos, size, style)
  • self.PostCreate(pre)
  • sizer = wx.BoxSizer(wx.VERTICAL)
  • textaprop=u"""
  • À propos de ce programme :
  • _____________________________
  • Créé par Aéra Group pour Code-SourceS.
  • Version """ + version + u""".2 ; Licence : Libre. Vous pouvez modifier ce que vous souhaité."""
  • label = wx.StaticText(self, -1, textaprop)
  • hyper = hl.HyperLinkCtrl(self, wx.ID_ANY, u"Source déposé sur Python-France",
  • URL=u"http://www.pythonfrance.com/")
  • sizer.Add(label, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • sizer.Add(hyper, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • btnsizer = wx.StdDialogButtonSizer()
  • if wx.Platform != u"__WXMSW__":
  • btn = wx.ContextHelpButton(self)
  • self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • btn = wx.Button(self, wx.ID_OK,u"OK")
  • btn.SetDefault()
  • sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)
  • self.SetSizer(sizer)
  • sizer.Fit(self)
  • class Modifier_mot_de_passe(wx.Dialog):
  • def __init__(
  • self, parent, ID, title,mot, size=wx.DefaultSize, pos=wx.DefaultPosition,
  • style=wx.DEFAULT_DIALOG_STYLE
  • ):
  • self.parent=parent
  • pre = wx.PreDialog()
  • pre.Create(parent, ID, title, pos, size, style)
  • self.PostCreate(pre)
  • sizer = wx.BoxSizer(wx.VERTICAL)
  • label = wx.StaticText(self, -1, u"Vous pouvez soit modifier le mot de passe soit le supprimer")
  • sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l1 = wx.StaticText(self, -1, u"Entrer le nouveau mot de passe")
  • box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e1 = wx.TextCtrl(self, -1, mot,style=wx.TE_PASSWORD, size=(180,-1))
  • box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l2 = wx.StaticText(self, -1, u"Confirmer le nouveau mot de passe")
  • box.Add(l2, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e2 = wx.TextCtrl(self, -1, mot,style=wx.TE_PASSWORD, size=(180,-1))
  • box.Add(self.e2, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • b1 = wx.Button(self, -1, u"Modifier le mot de passe")
  • b2 = wx.Button(self, -1, u"Supprimer le mot de passe")
  • b1.SetDefault()
  • sizer.Add(b1, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • sizer.Add(b2, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • self.Bind(wx.EVT_BUTTON, self.modif, b1)
  • self.Bind(wx.EVT_BUTTON, self.supprimer, b2)
  • btnsizer = wx.StdDialogButtonSizer()
  • if wx.Platform != u"__WXMSW__":
  • btn = wx.ContextHelpButton(self)
  • self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • btn = wx.Button(self, wx.ID_CANCEL,u"Fermer cette fenêtre")
  • sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)
  • self.SetSizer(sizer)
  • sizer.Fit(self)
  • def modif(self,evt):
  • if self.e1.GetValue()==u"" or self.e2.GetValue()==u"":
  • dia=wx.MessageDialog(self, u"Un ou plusieurs champs d'entréé sont vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • if self.e1.GetValue()==self.e2.GetValue():
  • dia=wx.MessageDialog(self, u"Le mouveau mot de passe protège votre documment", caption = u"Confirmation", style = wx.OK|wx.wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • self.parent.valider_mot_de_passe(self.e2.GetValue())
  • self.Destroy()
  • else:
  • dia=wx.MessageDialog(self, u"Les deux mots de passe sont différent", caption = u"Erreur", style = wx.OK|wx.wx.ICON_EXCLAMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • def supprimer(self,evt):
  • self.parent.valider_mot_de_passe(u"")
  • self.Destroy()
  • class Ajouter_mot_de_passe(wx.Dialog):
  • def __init__(
  • self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition,
  • style=wx.DEFAULT_DIALOG_STYLE
  • ):
  • self.parent=parent
  • pre = wx.PreDialog()
  • pre.Create(parent, ID, title, pos, size, style)
  • self.PostCreate(pre)
  • sizer = wx.BoxSizer(wx.VERTICAL)
  • label = wx.StaticText(self, -1, u"Entrer le mot de passe et confirmé le.\nEn cas de perte, il sera impossible d'ouvrir la liste")
  • sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l1 = wx.StaticText(self, -1, u"Entrer le mot de passe")
  • box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e1 = wx.TextCtrl(self, -1, u"",style=wx.TE_PASSWORD, size=(180,-1))
  • box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l2 = wx.StaticText(self, -1, u"Confirmer le mot de passe")
  • box.Add(l2, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e2 = wx.TextCtrl(self, -1, u"",style=wx.TE_PASSWORD, size=(180,-1))
  • box.Add(self.e2, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • b = wx.Button(self, -1, u"Ajouter le mot de passe")
  • b.SetDefault()
  • sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • self.Bind(wx.EVT_BUTTON, self.valide, b)
  • btnsizer = wx.StdDialogButtonSizer()
  • if wx.Platform != "__WXMSW__":
  • btn = wx.ContextHelpButton(self)
  • self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • btn = wx.Button(self, wx.ID_CANCEL,u"Fermer cette fenêtre")
  • sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)
  • self.SetSizer(sizer)
  • sizer.Fit(self)
  • def valide(self,evt):
  • if self.e1.GetValue()==u"" or self.e2.GetValue()==u"":
  • dia=wx.MessageDialog(self, u"Un ou plusieurs champs d'entréé sont vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • if self.e1.GetValue()==self.e2.GetValue():
  • dia=wx.MessageDialog(self, u"Le mot de passe protège votre documment", caption = u"Confirmation", style = wx.OK|wx.wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • self.parent.valider_mot_de_passe(self.e2.GetValue())
  • self.Destroy()
  • else:
  • dia=wx.MessageDialog(self, u"Les deux mots de passe sont différent", caption = u"Erreur", style = wx.OK|wx.wx.ICON_EXCLAMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • class Dialog_Nouveau(wx.Dialog):
  • def __init__(
  • self, parent, ID, title,nb,nom, size=wx.DefaultSize, pos=wx.DefaultPosition,
  • style=wx.DEFAULT_DIALOG_STYLE
  • ):
  • self.nb=nb
  • self.parent=parent
  • pre = wx.PreDialog()
  • pre.Create(parent, ID, title, pos, size, style)
  • self.PostCreate(pre)
  • sizer = wx.BoxSizer(wx.VERTICAL)
  • label = wx.StaticText(self, -1, u"Entrer les informations du nouveau contacte")
  • sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l1 = wx.StaticText(self, -1, u"Nom")
  • box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e1 = wx.TextCtrl(self, -1, nom[0], size=(180,-1))
  • box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l2 = wx.StaticText(self, -1, u"Prénom")
  • box.Add(l2, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e2 = wx.TextCtrl(self, -1, nom[1], size=(180,-1))
  • box.Add(self.e2, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l3 = wx.StaticText(self, -1, u"Adresse")
  • box.Add(l3, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e3 = wx.TextCtrl(self, -1, nom[2], size=(180,-1))
  • box.Add(self.e3, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l4 = wx.StaticText(self, -1, u"Téléphone")
  • box.Add(l4, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e4 = wx.TextCtrl(self, -1, nom[3], size=(180,-1))
  • box.Add(self.e4, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l5 = wx.StaticText(self, -1, u"Date de naissance")
  • box.Add(l5, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e5 = wx.TextCtrl(self, -1, nom[4], size=(180,-1))
  • box.Add(self.e5, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l6 = wx.StaticText(self, -1, u"E-mail")
  • box.Add(l6, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e6 = wx.TextCtrl(self, -1, nom[5], size=(180,-1))
  • box.Add(self.e6, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • box = wx.BoxSizer(wx.HORIZONTAL)
  • l7 = wx.StaticText(self, -1, u"Remarque(s)")
  • box.Add(l7, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
  • self.e7 = wx.TextCtrl(self, -1, nom[6], size=(180,-1))
  • box.Add(self.e7, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
  • sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • b = wx.Button(self, -1, u"Ajouter ce contacte")
  • b.SetDefault()
  • sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
  • self.Bind(wx.EVT_BUTTON, self.valide, b)
  • btnsizer = wx.StdDialogButtonSizer()
  • if wx.Platform != u"__WXMSW__":
  • btn = wx.ContextHelpButton(self)
  • self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • btn = wx.Button(self, wx.ID_CANCEL,u"Fermer cette fenêtre")
  • sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)
  • sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)
  • self.SetSizer(sizer)
  • sizer.Fit(self)
  • def valide(self,evt):
  • if self.e1.GetValue()==u"" and self.e2.GetValue()==u"":
  • dia=wx.MessageDialog(self, u"Rentrez au moin un nom et/ou un prénom", caption = u"Manque de donnée", style = wx.OK|wx.wx.ICON_EXCLAMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • self.parent.liste.InsertStringItem(self.nb,self.e1.GetValue())
  • self.parent.liste.SetStringItem(self.nb,1,self.e2.GetValue())
  • self.parent.liste.SetStringItem(self.nb,2,self.e3.GetValue())
  • self.parent.liste.SetStringItem(self.nb,3,self.e4.GetValue())
  • self.parent.liste.SetStringItem(self.nb,4,self.e5.GetValue())
  • self.parent.liste.SetStringItem(self.nb,5,self.e6.GetValue())
  • self.parent.liste.SetStringItem(self.nb,6,self.e7.GetValue())
  • self.Destroy()
  • a=[[self.e1.GetValue(),self.e2.GetValue(),self.e3.GetValue(),self.e4.GetValue(),self.e5.GetValue(),self.e6.GetValue(),self.e7.GetValue()]]
  • self.parent.listeitem[self.nb:self.nb]=a
  • class Frame(wx.Frame):
  • def __init__(self, parent, title):
  • wx.Frame.__init__(self, parent, -1, title,size=((1100, 600)))
  • self.Bind(wx.EVT_CLOSE, self.quitter)
  • self.nb=0
  • self.selec=u''
  • self.passe=u""
  • self.titre=u"Sans titre"
  • self.listeitem=[]
  • self.chemin=u'Pas enregistré'
  • self.menuBar = wx.MenuBar()
  • self.menu = wx.Menu()
  • self.menu.Append(11,u"Nouveau\tCtrl+N", u"Ouvrir une nouvelle fenêtre")
  • self.menu.Append(12,u"Enregistrer\tCtrl+E", u"Enregistrer la liste actuel")
  • self.menu.Append(13,u"Ouvrir\tCtrl+O", u"Ouvrir une liste prè-enregistrer")
  • self.menu.AppendSeparator()
  • self.menu.Append(14,u"Apperçu avant impression\tCtrl+P", u"Imprimer la liste actuel")
  • self.menu.AppendSeparator()
  • self.menu.Append(15,u"Propriétés", u"Propriété du document")
  • self.menu.AppendSeparator()
  • self.menu.Append(16,u"Quitter\tAlt-F4", u"Quitter le programme")
  • self.Bind(wx.EVT_MENU, self.nouveau_document, id=11)
  • self.Bind(wx.EVT_MENU, self.enregistrer, id=12)
  • self.Bind(wx.EVT_MENU, self.ouvrir, id=13)
  • self.Bind(wx.EVT_MENU, self.imprimer, id=14)
  • self.Bind(wx.EVT_MENU, self.propriete, id=15)
  • self.Bind(wx.EVT_MENU, self.quitter, id=16)
  • self.menuBar.Append(self.menu, u"&Fichier")
  • self.menu2 = wx.Menu()
  • self.menu2.Append(21,u"Ajouter un contacte\tCtrl+A", u"Ajouter un contacte à la liste sélectionnée")
  • self.menu2.Append(22,u"Supprimer un contacte\tSuppr", u"Supprimé un ou plusieur contacte de la liste")
  • self.menu2.Append(23,u"Éditer un contacte", u"Modifier un contacte de la liste")
  • self.menu2.AppendSeparator()
  • self.menu2.Append(24,u"Mot de passe", u"Protéger votre documment par un mot de passe")
  • self.menu2.Append(25,u"Modifier/Supprimer le mot de passe", u"Éditer le mot de passe préalablement entrée")
  • self.menuBar.Append(self.menu2, u"&Édition")
  • self.menu2.Enable(25,False)
  • self.Bind(wx.EVT_MENU, self.nouveau, id=21)
  • self.Bind(wx.EVT_MENU, self.supprimer, id=22)
  • self.Bind(wx.EVT_MENU, self.edite, id=23)
  • self.Bind(wx.EVT_MENU, self.entrer_motdepasse, id=24)
  • self.Bind(wx.EVT_MENU, self.modif_mot_de_passe, id=25)
  • self.menu3 = wx.Menu()
  • self.menu3.Append(31,u"Aide\tF1", u"Obtenir de l'aide")
  • self.menu3.AppendSeparator()
  • self.menu3.Append(32,u"À propos de ...\tF2", u"Imformation générale")
  • self.Bind(wx.EVT_MENU, self.aide, id=31)
  • self.Bind(wx.EVT_MENU, self.about, id=32)
  • self.menuBar.Append(self.menu3, u"&Aide")
  • self.SetMenuBar(self.menuBar)
  • self.CreateStatusBar()
  • panel = wx.Panel(self)
  • box = wx.StaticBox(panel, -1, u"Édition de la liste")
  • bsizer = wx.StaticBoxSizer(box, wx.HORIZONTAL)
  • b11 = wx.Button(panel, -1, u"Entrer un nouveau contacte")
  • b12 = wx.Button(panel, -1, u"Supprimer le contacte")
  • b13 = wx.Button(panel, -1, u"Éditer le contacte")
  • bsizer.Add(b11, 10,wx.LEFT|wx.ALL, 10)
  • bsizer.Add(b12, 10,wx.CENTER|wx.ALL, 10)
  • bsizer.Add(b13, 10,wx.RIGHT|wx.ALL, 10)
  • box1 = wx.StaticBox(panel, -1, u"Exportation")
  • bsizer1 = wx.StaticBoxSizer(box1, wx.HORIZONTAL)
  • b21 = wx.Button(panel, -1, u"Sauvegarder")
  • b22 = wx.Button(panel, -1, u"Apperçu avant impression")
  • bsizer1.Add(b21, 10,wx.LEFT|wx.ALL, 10)
  • bsizer1.Add(b22, 10,wx.RIGHT|wx.ALL, 10)
  • self.liste = wx.ListCtrl(panel,-1,size=(1000,300),style=wx.LC_REPORT)
  • self.liste.InsertColumn(0, u"Nom")
  • self.liste.InsertColumn(1, u"Prenom")
  • self.liste.InsertColumn(2, u"Adresse")
  • self.liste.InsertColumn(3, u"Téléphone")
  • self.liste.InsertColumn(4, u"Date de naissance")
  • self.liste.InsertColumn(5, u"E-mail")
  • self.liste.InsertColumn(6, u"Remarque(s)")
  • self.liste.SetColumnWidth(0,140)
  • self.liste.SetColumnWidth(1,140)
  • self.liste.SetColumnWidth(2,140)
  • self.liste.SetColumnWidth(3,140)
  • self.liste.SetColumnWidth(4,140)
  • self.liste.SetColumnWidth(5,140)
  • self.liste.SetColumnWidth(6,140)
  • self.Bind(wx.EVT_BUTTON, self.nouveau, b11)
  • self.Bind(wx.EVT_BUTTON, self.supprimer, b12)
  • self.Bind(wx.EVT_BUTTON, self.edite, b13)
  • self.Bind(wx.EVT_BUTTON, self.enregistrer, b21)
  • self.Bind(wx.EVT_BUTTON, self.imprimer, b22)
  • self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.selection, self.liste)
  • self.Bind(wx.EVT_LIST_ITEM_DESELECTED, self.deselection, self.liste)
  • self.liste.Bind(wx.EVT_CHAR, self.clavier)
  • self.liste.Bind(wx.EVT_LEFT_DCLICK, self.edite)
  • sizer = wx.BoxSizer(wx.VERTICAL)
  • boit = wx.BoxSizer(wx.HORIZONTAL)
  • boit.Add(bsizer, 0, wx.ALL, 10)
  • boit.Add(bsizer1, 0, wx.ALL, 10)
  • sizer.Add(boit, 0, wx.ALL|wx.CENTER, 10)
  • sizer.Add(self.liste, 1, wx.ALL|wx.CENTER, 0)
  • panel.SetSizer(sizer)
  • panel.Layout()
  • self.Centre()
  • def quitter(self, evt):
  • dia=wx.MessageDialog(self, u"Voullez-vous quitter le programme ?", caption = u"Quitter le programme", style = wx.YES_NO|wx.ICON_QUESTION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • if valeur==wx.ID_YES:
  • self.Destroy()
  • def renvoie(self,index, collone):
  • item = self.liste.GetItem(index, collone)
  • return item.GetText()
  • def selection(self,event):
  • self.selec=event.m_itemIndex
  • def supprimer(self,evt):
  • if self.selec=='':
  • dia=wx.MessageDialog(self, u"Vous n'avez pas sélectionné de contacte", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • dia=wx.MessageDialog(self, u"Êtes vous sûr de vouloir supprimer le contacte "+self.liste.GetItemText(self.selec)+u" "+self.renvoie(self.selec,1), caption = u"Confirmation", style = wx.YES_NO|wx.NO_DEFAULT|wx.ICON_QUESTION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • if valeur==wx.ID_YES:
  • liste_item=[]
  • liste_item.append(self.liste.GetItemText(self.selec))
  • i=1
  • while i<7:
  • liste_item.append(self.renvoie(self.selec,i))
  • i=i+1
  • self.listeitem.remove(liste_item)
  • self.liste.DeleteItem(self.selec)
  • self.nb=self.nb-1
  • self.selec=''
  • def deselection(self,evt):
  • self.selec=''
  • def nouveau(self,evt):
  • dlg = Dialog_Nouveau(self, -1, u"Ajouter un nouveau contacte",self.nb,[u'',u'',u'',u'',u'',u'',u''], size=(350, 200),
  • style = wx.DEFAULT_DIALOG_STYLE)
  • dlg.CenterOnScreen()
  • val = dlg.ShowModal()
  • self.nb=self.nb+1
  • def edite(self,evt):
  • if self.selec!='':
  • liste_item=[]
  • liste_item.append(self.liste.GetItemText(self.selec))
  • i=1
  • while i<7:
  • liste_item.append(self.renvoie(self.selec,i))
  • i=i+1
  • dlg = Dialog_Nouveau(self, -1, u"Éditer un contacte",self.selec,liste_item, size=(350, 200),
  • style = wx.DEFAULT_DIALOG_STYLE)
  • dlg.CenterOnScreen()
  • val = dlg.ShowModal()
  • if val!=wx.ID_CANCEL:
  • self.listeitem.remove(liste_item)
  • self.liste.DeleteItem(self.selec+1)
  • else:
  • dia=wx.MessageDialog(self, u"Vous n'avez pas sélectionné de contacte", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • def imprimer(self, evt):
  • if self.listeitem==[]:
  • dia=wx.MessageDialog(self, u"Il n'y a rien à imprimmer", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • prt = printout.PrintTable(self)
  • prt.SetLandscape()
  • prt.SetHeader("Liste de contacte - " + self.titre)
  • prt.label = [u"Nom", u"Prénom", u"Adresse",u"Numéro de tél",u"Date de naissance",u"E-mail",u"Remarque(s)"]
  • prt.set_column = []
  • prt.data = self.listeitem
  • prt.SetFooter(u"Page ", type =u"Num")
  • prt.Preview()
  • def entrer_motdepasse(self,evt):
  • dlg = Ajouter_mot_de_passe(self, -1, u"Entrer un mot de passe", size=(350, 200),
  • style = wx.DEFAULT_DIALOG_STYLE)
  • dlg.CenterOnScreen()
  • val = dlg.ShowModal()
  • def valider_mot_de_passe(self,mot):
  • self.passe=mot
  • if self.passe!="":
  • self.menu2.Enable(24,False)
  • self.menu2.Enable(25,True)
  • else:
  • self.menu2.Enable(24,True)
  • self.menu2.Enable(25,False)
  • def modif_mot_de_passe(self,evt):
  • dlg = Modifier_mot_de_passe(self, -1, u"Modifier/Supprimer le mot de passe",self.passe, size=(350, 200),
  • style = wx.DEFAULT_DIALOG_STYLE)
  • dlg.CenterOnScreen()
  • val = dlg.ShowModal()
  • def nouveau_document(self,evt):
  • dia=wx.MessageDialog(self, u"Êtes vous sûr de vouloir supprimer tous les contacte de la liste", caption = u"Confirmation", style = wx.YES_NO|wx.NO_DEFAULT|wx.ICON_QUESTION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • if valeur==wx.ID_YES:
  • self.nb=0
  • self.selec=u''
  • self.passe=u""
  • self.titre=u"Sans titre"
  • self.listeitem=[]
  • self.chemin=u'Pas enregistré'
  • self.SetTitle(u"Carnet d'adresse - Sans titre [Pas enregistré]")
  • self.menu2.Enable(24,True)
  • self.menu2.Enable(25,False)
  • self.liste.DeleteAllItems()
  • def about(self,evt):
  • dlg = About(self, -1, u"À propos de ...")
  • dlg.CenterOnScreen()
  • val = dlg.ShowModal()
  • def clavier(self,evt=None):
  • if evt.GetKeyCode()==127:
  • self.supprimer(None)
  • def enregistrer(self,evt):
  • global version
  • dlg = wx.FileDialog(self, message=u"Enregistrement de la liste", defaultDir=os.getcwd(),
  • defaultFile="", wildcard=u"Fichier liste d'adresse (*.list)|*.list", style=wx.SAVE)
  • if dlg.ShowModal() == wx.ID_OK:
  • fi=dlg.GetPath()
  • fichier = "CARNET ADRESSE\nFichier liste\n" + str(version) + '\n'
  • if self.passe!="":
  • fichier = fichier + '1\n' + unicode(self.passe, 'windows-1252') + "\n"
  • else:
  • fichier = fichier + '0\n'
  • fichier = fichier + self.titre + "\n" + str(self.listeitem)
  • enr=open(fi,'w')
  • enr.write(fichier.encode("windows-1252"))
  • enr.close()
  • self.SetTitle("Carnet d'adresse - " + self.titre +" [" + fi +"]")
  • def ouvrir(self,evt):
  • global version
  • dia=wx.MessageDialog(self, u"Êtes vous sûr de vouloir supprimer tous les contacte de la liste", caption = u"Confirmation", style = wx.YES_NO|wx.NO_DEFAULT|wx.ICON_QUESTION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • if valeur==wx.ID_YES:
  • dlg = wx.FileDialog(self, message=u"Importer des données", defaultDir=os.getcwd(),
  • defaultFile="", wildcard=u"Fichier liste d'adresse (*.list)|*.list|Tout les fichiers|*.*", style=wx.OPEN)
  • if dlg.ShowModal() == wx.ID_OK:
  • fichier = dlg.GetPaths()
  • fichier = fichier[0]
  • f=open(fichier,'r')
  • l1=f.readline()
  • l2=f.readline()
  • if l1==u"CARNET ADRESSE\n" and l2== u"Fichier liste\n":
  • l3=f.readline()
  • if l3==version+"\n" or l3=='1.0\n':
  • l4=f.readline()
  • if l4=='1\n':
  • l44=f.readline()
  • dlg = Accee_document(self, -1, u"Restriction")
  • dlg.CenterOnScreen()
  • val = dlg.ShowModal()
  • if val==wx.ID_CANCEL:
  • f.close()
  • return
  • else:
  • if dlg.valeur==l44[:len(l44)-1]:
  • dia=wx.MessageDialog(self, u"Mot passe bon", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • self.valider_mot_de_passe(l44[:len(l44)-1])
  • elif dlg.valeur==u"motdepasse": # C'est un petit plus pour nous programateur : En tapant se mot de passe on peut ouvrir n'importe quel document
  • dia=wx.MessageDialog(self, u"Accée réservé au programmateur", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • self.valider_mot_de_passe(l44[:len(l44)-1])
  • else:
  • dia=wx.MessageDialog(self, u"Mot de passe faut", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • f.close()
  • return
  • else:
  • self.valider_mot_de_passe("")
  • l5=f.readline()
  • l6=f.readline()
  • f.close()
  • self.liste.DeleteAllItems()
  • l6=eval(l6)
  • i=0
  • nbliste=len(l6)
  • self.nb=0
  • while i<nbliste:
  • k=l6[i]
  • self.liste.InsertStringItem(self.nb,k[0])
  • self.liste.SetStringItem(self.nb,1,k[1])
  • self.liste.SetStringItem(self.nb,2,k[2])
  • self.liste.SetStringItem(self.nb,3,k[3])
  • self.liste.SetStringItem(self.nb,4,k[4])
  • self.liste.SetStringItem(self.nb,5,k[5])
  • self.liste.SetStringItem(self.nb,6,k[6])
  • self.nb=self.nb+1
  • i=i+1
  • self.selec=''
  • self.titre=l5[:len(l5)-1]
  • self.listeitem=l6
  • self.chemin=fichier
  • self.SetTitle(u"Carnet d'adresse - " + unicode(self.titre, 'windows-1252') + u" [" + self.chemin + u"]")
  • else:
  • dia=wx.MessageDialog(self, u"Ceci n'est pas un fichier dont la version ne correspond pas", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • else:
  • dia=wx.MessageDialog(self, u"Ceci n'est pas un fichier lisible par le programme", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • def propriete(self,evt):
  • dlg = Propriete_document(self, -1, u"Propriété du document")
  • dlg.CenterOnScreen()
  • val = dlg.ShowModal()
  • def aide(self,evt):
  • dia=wx.MessageDialog(self, u"Attendez la version 2.0 !!!", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
  • pos = wx.DefaultPosition)
  • valeur = dia.ShowModal()
  • class MyApp(wx.App):
  • def OnInit(self):
  • frame = Frame(None, u"Carnet d'adresse - Sans titre [Pas enregistré]")
  • self.SetTopWindow(frame)
  • frame.Show(True)
  • return True
  • app = MyApp(True)
  • app.MainLoop()
import wx
import os
import  wx.lib.printout as printout
import wx.lib.hyperlink as hl

#############

provider = wx.SimpleHelpProvider()
wx.HelpProvider_Set(provider)


#########################################

version=u"1.1"

#########################################

class Propriete_document(wx.Dialog):
    def __init__(
            self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition, 
            style=wx.DEFAULT_DIALOG_STYLE
            ):        
        self.parent=parent
        pre = wx.PreDialog()
        pre.Create(parent, ID, title, pos, size, style)

        self.PostCreate(pre)

        sizer = wx.BoxSizer(wx.VERTICAL)

        label = wx.StaticText(self, -1, u"Propriétée du document\nDans les prochaine version, plus d'indormarion seront répertorié")
        sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l1 = wx.StaticText(self, -1, u"Nom du document")
        box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e1 = wx.TextCtrl(self, -1, self.parent.titre, size=(180,-1))
        box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        
        b = wx.Button(self, -1, u"OK")
        b.SetDefault()

        
        sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
        self.Bind(wx.EVT_BUTTON, self.valide, b)



        btnsizer = wx.StdDialogButtonSizer()
        
        if wx.Platform != u"__WXMSW__":
            btn = wx.ContextHelpButton(self)
            self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
            
        btn = wx.Button(self, wx.ID_CANCEL,u"Annuler")

        sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)

        sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)

        self.SetSizer(sizer)
        sizer.Fit(self)
        
    def valide(self,evt):
        if self.e1.GetValue()=="":
            dia=wx.MessageDialog(self, u"Le champs d'entréé est vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
        else:
            self.Destroy()
            self.parent.titre= self.e1.GetValue()
            self.parent.SetTitle(u"Carnet d'adresse - " + self.e1.GetValue() +u" [" + self.parent.chemin +u"]")
            


class Accee_document(wx.Dialog):
    def __init__(
            self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition, 
            style=wx.DEFAULT_DIALOG_STYLE
            ):        
        self.parent=parent
        pre = wx.PreDialog()
        pre.Create(parent, ID, title, pos, size, style)

        self.PostCreate(pre)

        sizer = wx.BoxSizer(wx.VERTICAL)

        label = wx.StaticText(self, -1, u"Ce document est protégé par un mot de passe\nEn cas de perte, il sera impossible d'ouvrir la liste")
        sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l1 = wx.StaticText(self, -1, u"Mot de passe")
        box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e1 = wx.TextCtrl(self, -1, "",style=wx.TE_PASSWORD, size=(180,-1))
        box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        
        b = wx.Button(self, -1, u"Valider")
        b.SetDefault()

        
        sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
        self.Bind(wx.EVT_BUTTON, self.valide, b)



        btnsizer = wx.StdDialogButtonSizer()
        
        if wx.Platform != u"__WXMSW__":
            btn = wx.ContextHelpButton(self)
            self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
            
        btn = wx.Button(self, wx.ID_CANCEL,u"Annuler")

        sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)

        sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)

        self.SetSizer(sizer)
        sizer.Fit(self)
        
    def valide(self,evt):
        if self.e1.GetValue()==u"":
            dia=wx.MessageDialog(self, u"Le champs d'entréé est vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
        else:
            self.Destroy()
            self.valeur= self.e1.GetValue().encode("windows-1252")

class About(wx.Dialog):
    def __init__(
            self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition, 
            style=wx.DEFAULT_DIALOG_STYLE
            ):
        global version
        
        pre = wx.PreDialog()
        pre.Create(parent, ID, title, pos, size, style)

        self.PostCreate(pre)

        sizer = wx.BoxSizer(wx.VERTICAL)
        


        textaprop=u"""
À propos de ce programme :
_____________________________

Créé par Aéra Group pour Code-SourceS.
Version """ + version + u""".2 ; Licence : Libre. Vous pouvez modifier ce que vous souhaité."""

        label = wx.StaticText(self, -1, textaprop)
        hyper = hl.HyperLinkCtrl(self, wx.ID_ANY, u"Source déposé sur Python-France",
                                        URL=u"http://www.pythonfrance.com/")
        sizer.Add(label, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
        sizer.Add(hyper, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        btnsizer = wx.StdDialogButtonSizer()
        
        if wx.Platform != u"__WXMSW__":
            btn = wx.ContextHelpButton(self)
            self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
            
        btn = wx.Button(self, wx.ID_OK,u"OK")
        btn.SetDefault()

        sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)

        sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)

        self.SetSizer(sizer)
        sizer.Fit(self)

class Modifier_mot_de_passe(wx.Dialog):
    def __init__(
            self, parent, ID, title,mot, size=wx.DefaultSize, pos=wx.DefaultPosition, 
            style=wx.DEFAULT_DIALOG_STYLE
            ):        
        self.parent=parent
        pre = wx.PreDialog()
        pre.Create(parent, ID, title, pos, size, style)

        self.PostCreate(pre)

        sizer = wx.BoxSizer(wx.VERTICAL)

        label = wx.StaticText(self, -1, u"Vous pouvez soit modifier le mot de passe soit le supprimer")
        sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l1 = wx.StaticText(self, -1, u"Entrer le nouveau mot de passe")
        box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e1 = wx.TextCtrl(self, -1, mot,style=wx.TE_PASSWORD, size=(180,-1))
        box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l2 = wx.StaticText(self, -1, u"Confirmer le nouveau mot de passe")
        box.Add(l2, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e2 = wx.TextCtrl(self, -1, mot,style=wx.TE_PASSWORD, size=(180,-1))
        box.Add(self.e2, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        
        b1 = wx.Button(self, -1, u"Modifier le mot de passe")
        b2 = wx.Button(self, -1, u"Supprimer le mot de passe")
        b1.SetDefault()

        
        sizer.Add(b1, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
        sizer.Add(b2, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
        self.Bind(wx.EVT_BUTTON, self.modif, b1)
        self.Bind(wx.EVT_BUTTON, self.supprimer, b2)



        btnsizer = wx.StdDialogButtonSizer()
        
        if wx.Platform != u"__WXMSW__":
            btn = wx.ContextHelpButton(self)
            self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
            
        btn = wx.Button(self, wx.ID_CANCEL,u"Fermer cette fenêtre")

        sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)

        sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)

        self.SetSizer(sizer)
        sizer.Fit(self)
        
    def modif(self,evt):
        if self.e1.GetValue()==u"" or self.e2.GetValue()==u"":
            dia=wx.MessageDialog(self, u"Un ou plusieurs champs d'entréé sont vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
        else:
            if self.e1.GetValue()==self.e2.GetValue():
                dia=wx.MessageDialog(self, u"Le mouveau mot de passe protège votre documment", caption = u"Confirmation", style = wx.OK|wx.wx.ICON_INFORMATION,
                                     pos = wx.DefaultPosition)
                valeur = dia.ShowModal()
                self.parent.valider_mot_de_passe(self.e2.GetValue())
                self.Destroy()
            else:
                dia=wx.MessageDialog(self, u"Les deux mots de passe sont différent", caption = u"Erreur", style = wx.OK|wx.wx.ICON_EXCLAMATION,
                                     pos = wx.DefaultPosition)
                valeur = dia.ShowModal()
                
    def supprimer(self,evt):
        self.parent.valider_mot_de_passe(u"")
        self.Destroy()

class Ajouter_mot_de_passe(wx.Dialog):
    def __init__(
            self, parent, ID, title, size=wx.DefaultSize, pos=wx.DefaultPosition, 
            style=wx.DEFAULT_DIALOG_STYLE
            ):        
        self.parent=parent
        pre = wx.PreDialog()
        pre.Create(parent, ID, title, pos, size, style)

        self.PostCreate(pre)

        sizer = wx.BoxSizer(wx.VERTICAL)

        label = wx.StaticText(self, -1, u"Entrer le mot de passe et confirmé le.\nEn cas de perte, il sera impossible d'ouvrir la liste")
        sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l1 = wx.StaticText(self, -1, u"Entrer le mot de passe")
        box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e1 = wx.TextCtrl(self, -1, u"",style=wx.TE_PASSWORD, size=(180,-1))
        box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l2 = wx.StaticText(self, -1, u"Confirmer le mot de passe")
        box.Add(l2, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e2 = wx.TextCtrl(self, -1, u"",style=wx.TE_PASSWORD, size=(180,-1))
        box.Add(self.e2, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        
        b = wx.Button(self, -1, u"Ajouter le mot de passe")
        b.SetDefault()

        
        sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
        self.Bind(wx.EVT_BUTTON, self.valide, b)



        btnsizer = wx.StdDialogButtonSizer()
        
        if wx.Platform != "__WXMSW__":
            btn = wx.ContextHelpButton(self)
            self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
            
        btn = wx.Button(self, wx.ID_CANCEL,u"Fermer cette fenêtre")

        sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)

        sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)

        self.SetSizer(sizer)
        sizer.Fit(self)
        
    def valide(self,evt):
        if self.e1.GetValue()==u"" or self.e2.GetValue()==u"":
            dia=wx.MessageDialog(self, u"Un ou plusieurs champs d'entréé sont vide", caption = u"Erreur-oublie", style = wx.OK|wx.wx.ICON_EXCLAMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
        else:
            if self.e1.GetValue()==self.e2.GetValue():
                dia=wx.MessageDialog(self, u"Le mot de passe protège votre documment", caption = u"Confirmation", style = wx.OK|wx.wx.ICON_INFORMATION,
                                     pos = wx.DefaultPosition)
                valeur = dia.ShowModal()
                self.parent.valider_mot_de_passe(self.e2.GetValue())
                self.Destroy()
            else:
                dia=wx.MessageDialog(self, u"Les deux mots de passe sont différent", caption = u"Erreur", style = wx.OK|wx.wx.ICON_EXCLAMATION,
                                     pos = wx.DefaultPosition)
                valeur = dia.ShowModal()

class Dialog_Nouveau(wx.Dialog):
    def __init__(
            self, parent, ID, title,nb,nom, size=wx.DefaultSize, pos=wx.DefaultPosition, 
            style=wx.DEFAULT_DIALOG_STYLE
            ):
        
        self.nb=nb       
        self.parent=parent
        
        
        pre = wx.PreDialog()
        pre.Create(parent, ID, title, pos, size, style)

        self.PostCreate(pre)

        sizer = wx.BoxSizer(wx.VERTICAL)

        label = wx.StaticText(self, -1, u"Entrer les informations du nouveau contacte")
        sizer.Add(label, 0, wx.ALIGN_CENTER|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l1 = wx.StaticText(self, -1, u"Nom")
        box.Add(l1, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e1 = wx.TextCtrl(self, -1, nom[0], size=(180,-1))
        box.Add(self.e1, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l2 = wx.StaticText(self, -1, u"Prénom")
        box.Add(l2, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e2 = wx.TextCtrl(self, -1, nom[1], size=(180,-1))
        box.Add(self.e2, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l3 = wx.StaticText(self, -1, u"Adresse")
        box.Add(l3, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e3 = wx.TextCtrl(self, -1, nom[2], size=(180,-1))
        box.Add(self.e3, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l4 = wx.StaticText(self, -1, u"Téléphone")
        box.Add(l4, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e4 = wx.TextCtrl(self, -1, nom[3], size=(180,-1))
        box.Add(self.e4, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l5 = wx.StaticText(self, -1, u"Date de naissance")
        box.Add(l5, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e5 = wx.TextCtrl(self, -1, nom[4], size=(180,-1))
        box.Add(self.e5, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l6 = wx.StaticText(self, -1, u"E-mail")
        box.Add(l6, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e6 = wx.TextCtrl(self, -1, nom[5], size=(180,-1))
        box.Add(self.e6, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        box = wx.BoxSizer(wx.HORIZONTAL)
        l7 = wx.StaticText(self, -1, u"Remarque(s)")
        box.Add(l7, 0, wx.GROW|wx.ALIGN_LEFT|wx.ALL, 5)
        self.e7 = wx.TextCtrl(self, -1, nom[6], size=(180,-1))
        box.Add(self.e7, 0, wx.GROW|wx.ALIGN_RIGHT|wx.ALL, 5)
        sizer.Add(box, 0, wx.ALIGN_CENTRE|wx.ALL, 5)

        
        b = wx.Button(self, -1, u"Ajouter ce contacte")
        b.SetDefault()

        
        sizer.Add(b, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
        self.Bind(wx.EVT_BUTTON, self.valide, b)



        btnsizer = wx.StdDialogButtonSizer()
        
        if wx.Platform != u"__WXMSW__":
            btn = wx.ContextHelpButton(self)
            self.box.Add(btn, 0, wx.ALL|wx.CENTER, 5)
            
        btn = wx.Button(self, wx.ID_CANCEL,u"Fermer cette fenêtre")

        sizer.Add(btn, 0, wx.ALL|wx.CENTER, 5)

        sizer.Add(btnsizer, 0, wx.ALL|wx.CENTER, 5)

        self.SetSizer(sizer)
        sizer.Fit(self)
        
    def valide(self,evt):
        if self.e1.GetValue()==u"" and self.e2.GetValue()==u"":
            dia=wx.MessageDialog(self, u"Rentrez au moin un nom et/ou un prénom", caption = u"Manque de donnée", style = wx.OK|wx.wx.ICON_EXCLAMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
        else:
            self.parent.liste.InsertStringItem(self.nb,self.e1.GetValue())
            self.parent.liste.SetStringItem(self.nb,1,self.e2.GetValue())
            self.parent.liste.SetStringItem(self.nb,2,self.e3.GetValue())
            self.parent.liste.SetStringItem(self.nb,3,self.e4.GetValue())
            self.parent.liste.SetStringItem(self.nb,4,self.e5.GetValue())
            self.parent.liste.SetStringItem(self.nb,5,self.e6.GetValue())
            self.parent.liste.SetStringItem(self.nb,6,self.e7.GetValue())
            self.Destroy()
            a=[[self.e1.GetValue(),self.e2.GetValue(),self.e3.GetValue(),self.e4.GetValue(),self.e5.GetValue(),self.e6.GetValue(),self.e7.GetValue()]]
            self.parent.listeitem[self.nb:self.nb]=a


class Frame(wx.Frame):
    def __init__(self, parent, title):
        wx.Frame.__init__(self, parent, -1, title,size=((1100, 600)))
        self.Bind(wx.EVT_CLOSE, self.quitter)

        
        self.nb=0
        self.selec=u''
        self.passe=u""
        self.titre=u"Sans titre"
        self.listeitem=[]
        self.chemin=u'Pas enregistré'

    
        self.menuBar = wx.MenuBar()

         
        self.menu = wx.Menu()

        self.menu.Append(11,u"Nouveau\tCtrl+N", u"Ouvrir une nouvelle fenêtre")
        self.menu.Append(12,u"Enregistrer\tCtrl+E", u"Enregistrer la liste actuel")
        self.menu.Append(13,u"Ouvrir\tCtrl+O", u"Ouvrir une liste prè-enregistrer")
        self.menu.AppendSeparator()
        self.menu.Append(14,u"Apperçu avant impression\tCtrl+P", u"Imprimer la liste actuel")
        self.menu.AppendSeparator()
        self.menu.Append(15,u"Propriétés", u"Propriété du document")
        self.menu.AppendSeparator()
        self.menu.Append(16,u"Quitter\tAlt-F4", u"Quitter le programme")

        self.Bind(wx.EVT_MENU, self.nouveau_document, id=11)
        self.Bind(wx.EVT_MENU, self.enregistrer, id=12)
        self.Bind(wx.EVT_MENU, self.ouvrir, id=13) 
        self.Bind(wx.EVT_MENU, self.imprimer, id=14)
        self.Bind(wx.EVT_MENU, self.propriete, id=15) 
        self.Bind(wx.EVT_MENU, self.quitter, id=16)


        self.menuBar.Append(self.menu, u"&Fichier")

        self.menu2 = wx.Menu()
        self.menu2.Append(21,u"Ajouter un contacte\tCtrl+A", u"Ajouter un contacte à la liste sélectionnée")
        self.menu2.Append(22,u"Supprimer un contacte\tSuppr", u"Supprimé un ou plusieur contacte de la liste")
        self.menu2.Append(23,u"Éditer un contacte", u"Modifier un contacte de la liste")
        self.menu2.AppendSeparator()
        self.menu2.Append(24,u"Mot de passe", u"Protéger votre documment par un mot de passe")
        self.menu2.Append(25,u"Modifier/Supprimer le mot de passe", u"Éditer le mot de passe préalablement entrée")
        self.menuBar.Append(self.menu2, u"&Édition")
        self.menu2.Enable(25,False)

        self.Bind(wx.EVT_MENU, self.nouveau, id=21)
        self.Bind(wx.EVT_MENU, self.supprimer, id=22)
        self.Bind(wx.EVT_MENU, self.edite, id=23)
        self.Bind(wx.EVT_MENU, self.entrer_motdepasse, id=24)
        self.Bind(wx.EVT_MENU, self.modif_mot_de_passe, id=25)

        self.menu3 = wx.Menu()
        self.menu3.Append(31,u"Aide\tF1", u"Obtenir de l'aide")
        self.menu3.AppendSeparator()
        self.menu3.Append(32,u"À propos de ...\tF2", u"Imformation générale")

        self.Bind(wx.EVT_MENU, self.aide, id=31)
        self.Bind(wx.EVT_MENU, self.about, id=32)


        self.menuBar.Append(self.menu3, u"&Aide")
        
        self.SetMenuBar(self.menuBar)


        self.CreateStatusBar()



        panel = wx.Panel(self)


        box = wx.StaticBox(panel, -1, u"Édition de la liste")
        bsizer = wx.StaticBoxSizer(box, wx.HORIZONTAL)
        b11 = wx.Button(panel, -1, u"Entrer un nouveau contacte")
        b12 = wx.Button(panel, -1, u"Supprimer le contacte")
        b13 = wx.Button(panel, -1, u"Éditer le contacte")
        bsizer.Add(b11, 10,wx.LEFT|wx.ALL, 10)
        bsizer.Add(b12, 10,wx.CENTER|wx.ALL, 10)
        bsizer.Add(b13, 10,wx.RIGHT|wx.ALL, 10)



        box1 = wx.StaticBox(panel, -1, u"Exportation")
        bsizer1 = wx.StaticBoxSizer(box1, wx.HORIZONTAL)
        b21 = wx.Button(panel, -1, u"Sauvegarder")
        b22 = wx.Button(panel, -1, u"Apperçu avant impression")
        bsizer1.Add(b21, 10,wx.LEFT|wx.ALL, 10)
        bsizer1.Add(b22, 10,wx.RIGHT|wx.ALL, 10)

        self.liste = wx.ListCtrl(panel,-1,size=(1000,300),style=wx.LC_REPORT)
        self.liste.InsertColumn(0, u"Nom")
        self.liste.InsertColumn(1, u"Prenom")
        self.liste.InsertColumn(2, u"Adresse")
        self.liste.InsertColumn(3, u"Téléphone")
        self.liste.InsertColumn(4, u"Date de naissance")
        self.liste.InsertColumn(5, u"E-mail")
        self.liste.InsertColumn(6, u"Remarque(s)")
        
        self.liste.SetColumnWidth(0,140)
        self.liste.SetColumnWidth(1,140)
        self.liste.SetColumnWidth(2,140)
        self.liste.SetColumnWidth(3,140)
        self.liste.SetColumnWidth(4,140)
        self.liste.SetColumnWidth(5,140)
        self.liste.SetColumnWidth(6,140)

        self.Bind(wx.EVT_BUTTON, self.nouveau, b11)
        self.Bind(wx.EVT_BUTTON, self.supprimer, b12)
        self.Bind(wx.EVT_BUTTON, self.edite, b13)
        self.Bind(wx.EVT_BUTTON, self.enregistrer, b21)
        self.Bind(wx.EVT_BUTTON, self.imprimer, b22)
        self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.selection, self.liste)
        self.Bind(wx.EVT_LIST_ITEM_DESELECTED, self.deselection, self.liste)
        self.liste.Bind(wx.EVT_CHAR, self.clavier)
        self.liste.Bind(wx.EVT_LEFT_DCLICK, self.edite)

        sizer = wx.BoxSizer(wx.VERTICAL)

        boit = wx.BoxSizer(wx.HORIZONTAL)
        
        boit.Add(bsizer, 0, wx.ALL, 10)
        boit.Add(bsizer1, 0, wx.ALL, 10)
        sizer.Add(boit, 0, wx.ALL|wx.CENTER, 10)

        sizer.Add(self.liste, 1, wx.ALL|wx.CENTER, 0)
        
        panel.SetSizer(sizer)
        panel.Layout()


        self.Centre()


    def quitter(self, evt):
            dia=wx.MessageDialog(self, u"Voullez-vous quitter le programme ?", caption = u"Quitter le programme", style = wx.YES_NO|wx.ICON_QUESTION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
            if valeur==wx.ID_YES:
                self.Destroy()
        
    def renvoie(self,index, collone):
        item = self.liste.GetItem(index, collone)
        return item.GetText()
        
    def selection(self,event):
        self.selec=event.m_itemIndex
        
    def supprimer(self,evt):
        if self.selec=='':
            dia=wx.MessageDialog(self, u"Vous n'avez pas sélectionné de contacte", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
        else:
            dia=wx.MessageDialog(self, u"Êtes vous sûr de vouloir supprimer le contacte "+self.liste.GetItemText(self.selec)+u" "+self.renvoie(self.selec,1), caption = u"Confirmation", style = wx.YES_NO|wx.NO_DEFAULT|wx.ICON_QUESTION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
            if valeur==wx.ID_YES:
                liste_item=[]
                liste_item.append(self.liste.GetItemText(self.selec))
                i=1
                while i<7:
                    liste_item.append(self.renvoie(self.selec,i))
                    i=i+1
                self.listeitem.remove(liste_item)
                self.liste.DeleteItem(self.selec)
                self.nb=self.nb-1              
                self.selec=''
        
    def deselection(self,evt):
        self.selec=''

    def nouveau(self,evt):
        dlg = Dialog_Nouveau(self, -1, u"Ajouter un nouveau contacte",self.nb,[u'',u'',u'',u'',u'',u'',u''], size=(350, 200),
                         style = wx.DEFAULT_DIALOG_STYLE)
        dlg.CenterOnScreen()
        val = dlg.ShowModal()
        self.nb=self.nb+1

    def edite(self,evt):
        if self.selec!='':
            liste_item=[]
            liste_item.append(self.liste.GetItemText(self.selec))
            i=1
            while i<7:
                liste_item.append(self.renvoie(self.selec,i))
                i=i+1
            dlg = Dialog_Nouveau(self, -1, u"Éditer un contacte",self.selec,liste_item, size=(350, 200),
                             style = wx.DEFAULT_DIALOG_STYLE)
            dlg.CenterOnScreen()
            val = dlg.ShowModal()
            if val!=wx.ID_CANCEL:
                self.listeitem.remove(liste_item)
                self.liste.DeleteItem(self.selec+1)            
        else:
            dia=wx.MessageDialog(self, u"Vous n'avez pas sélectionné de contacte", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()

    def imprimer(self, evt):
        if self.listeitem==[]:
            dia=wx.MessageDialog(self, u"Il n'y a rien à imprimmer", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                 pos = wx.DefaultPosition)
            valeur = dia.ShowModal()
        else:
            prt = printout.PrintTable(self)       
            prt.SetLandscape()
            prt.SetHeader("Liste de contacte - " + self.titre)
            prt.label = [u"Nom", u"Prénom", u"Adresse",u"Numéro de tél",u"Date de naissance",u"E-mail",u"Remarque(s)"]
            prt.set_column = []
            prt.data = self.listeitem
            prt.SetFooter(u"Page ", type =u"Num")
            prt.Preview()

    def entrer_motdepasse(self,evt):
        dlg = Ajouter_mot_de_passe(self, -1, u"Entrer un mot de passe", size=(350, 200),
                             style = wx.DEFAULT_DIALOG_STYLE)
        dlg.CenterOnScreen()
        val = dlg.ShowModal()

    def valider_mot_de_passe(self,mot):
        self.passe=mot
        if self.passe!="":
            self.menu2.Enable(24,False)
            self.menu2.Enable(25,True)
        else:
            self.menu2.Enable(24,True)
            self.menu2.Enable(25,False)
            
    def modif_mot_de_passe(self,evt):
        dlg = Modifier_mot_de_passe(self, -1, u"Modifier/Supprimer le mot de passe",self.passe, size=(350, 200),
                             style = wx.DEFAULT_DIALOG_STYLE)
        dlg.CenterOnScreen()
        val = dlg.ShowModal()

    def nouveau_document(self,evt):
        dia=wx.MessageDialog(self, u"Êtes vous sûr de vouloir supprimer tous les contacte de la liste", caption = u"Confirmation", style = wx.YES_NO|wx.NO_DEFAULT|wx.ICON_QUESTION,
                                 pos = wx.DefaultPosition)
        valeur = dia.ShowModal()
        if valeur==wx.ID_YES:
            self.nb=0
            self.selec=u''
            self.passe=u""
            self.titre=u"Sans titre"
            self.listeitem=[]
            self.chemin=u'Pas enregistré'
            
            self.SetTitle(u"Carnet d'adresse - Sans titre [Pas enregistré]")
            self.menu2.Enable(24,True)
            self.menu2.Enable(25,False)
            self.liste.DeleteAllItems()

    def about(self,evt):
        dlg = About(self, -1, u"À propos de ...")
        dlg.CenterOnScreen()
        val = dlg.ShowModal()

    def clavier(self,evt=None):
        if evt.GetKeyCode()==127:
            self.supprimer(None)

    def enregistrer(self,evt):
        global version        
        dlg = wx.FileDialog(self, message=u"Enregistrement de la liste", defaultDir=os.getcwd(),
                                    defaultFile="", wildcard=u"Fichier liste d'adresse (*.list)|*.list", style=wx.SAVE)
        if dlg.ShowModal() == wx.ID_OK:
            fi=dlg.GetPath()                    
            fichier = "CARNET ADRESSE\nFichier liste\n" + str(version) + '\n'
            if self.passe!="":
                fichier = fichier + '1\n' + unicode(self.passe, 'windows-1252') + "\n"
            else:
                fichier = fichier + '0\n'
            fichier = fichier + self.titre + "\n" + str(self.listeitem)

            enr=open(fi,'w')
            enr.write(fichier.encode("windows-1252"))
            enr.close()
            
            self.SetTitle("Carnet d'adresse - " + self.titre +" [" + fi +"]")

    def ouvrir(self,evt):
        global version
        dia=wx.MessageDialog(self, u"Êtes vous sûr de vouloir supprimer tous les contacte de la liste", caption = u"Confirmation", style = wx.YES_NO|wx.NO_DEFAULT|wx.ICON_QUESTION,
                                 pos = wx.DefaultPosition)
        valeur = dia.ShowModal()
        if valeur==wx.ID_YES:        
            dlg = wx.FileDialog(self, message=u"Importer des données", defaultDir=os.getcwd(), 
            defaultFile="", wildcard=u"Fichier liste d'adresse (*.list)|*.list|Tout les fichiers|*.*", style=wx.OPEN)
            
            if dlg.ShowModal() == wx.ID_OK:
                fichier = dlg.GetPaths()
                fichier = fichier[0]                            
                f=open(fichier,'r')
                l1=f.readline()
                l2=f.readline()
                if l1==u"CARNET ADRESSE\n" and l2== u"Fichier liste\n":
                    l3=f.readline()
                    if l3==version+"\n" or l3=='1.0\n':
                        l4=f.readline()
                        if l4=='1\n':
                            l44=f.readline()
                            dlg = Accee_document(self, -1, u"Restriction")
                            dlg.CenterOnScreen()
                            val = dlg.ShowModal()
                            if val==wx.ID_CANCEL:
                                f.close()
                                return
                            else:
                                if dlg.valeur==l44[:len(l44)-1]:
                                    dia=wx.MessageDialog(self, u"Mot passe bon", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                         pos = wx.DefaultPosition)
                                    valeur = dia.ShowModal()
                                    self.valider_mot_de_passe(l44[:len(l44)-1])
                                elif dlg.valeur==u"motdepasse": # C'est un petit plus pour nous programateur : En tapant se mot de passe on peut ouvrir n'importe quel document
                                    dia=wx.MessageDialog(self, u"Accée réservé au programmateur", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                         pos = wx.DefaultPosition)
                                    valeur = dia.ShowModal()
                                    self.valider_mot_de_passe(l44[:len(l44)-1])
                                else:
                                    dia=wx.MessageDialog(self, u"Mot de passe faut", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                         pos = wx.DefaultPosition)
                                    valeur = dia.ShowModal()
                                    f.close()
                                    return
                        else:
                           self.valider_mot_de_passe("")
                        l5=f.readline()
                        l6=f.readline()
                        f.close()

                        self.liste.DeleteAllItems()

                        l6=eval(l6)
                        i=0
                        nbliste=len(l6)
                        self.nb=0
                        while i<nbliste:
                            k=l6[i]
                            self.liste.InsertStringItem(self.nb,k[0])
                            self.liste.SetStringItem(self.nb,1,k[1])
                            self.liste.SetStringItem(self.nb,2,k[2])
                            self.liste.SetStringItem(self.nb,3,k[3])
                            self.liste.SetStringItem(self.nb,4,k[4])
                            self.liste.SetStringItem(self.nb,5,k[5])
                            self.liste.SetStringItem(self.nb,6,k[6])
                            self.nb=self.nb+1
                            i=i+1

                        self.selec=''
                        self.titre=l5[:len(l5)-1]
                        self.listeitem=l6
                        self.chemin=fichier

                        self.SetTitle(u"Carnet d'adresse - " + unicode(self.titre, 'windows-1252') + u" [" + self.chemin + u"]")
                    else:
                        dia=wx.MessageDialog(self, u"Ceci n'est pas un fichier dont la version ne correspond pas", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                         pos = wx.DefaultPosition)
                        valeur = dia.ShowModal()
                else:
                    dia=wx.MessageDialog(self, u"Ceci n'est pas un fichier lisible par le programme", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                         pos = wx.DefaultPosition)
                    valeur = dia.ShowModal()
                    
    def propriete(self,evt):
        dlg = Propriete_document(self, -1, u"Propriété du document")
        dlg.CenterOnScreen()
        val = dlg.ShowModal()

    def aide(self,evt):
        dia=wx.MessageDialog(self, u"Attendez la version 2.0 !!!", caption = u"Information", style = wx.OK|wx.ICON_INFORMATION,
                                         pos = wx.DefaultPosition)
        valeur = dia.ShowModal()
 

class MyApp(wx.App):
    def OnInit(self):
        frame = Frame(None, u"Carnet d'adresse - Sans titre [Pas enregistré]")
        self.SetTopWindow(frame)

        frame.Show(True)
        return True
        
app = MyApp(True)
app.MainLoop()

 Conclusion

POUR CEUX QUI DÉSIR TÉLÉCHARGER WX.PYTHON :

Allez sur le site http://www.wxpython.org/download.php et sélectionner la version correspondant à votre version de Python et à votre système d'exploitation.

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Historique

01 juin 2007 09:17:38 :
Ajout de l'unicode à la source : permet d'entrée des chaine accentuées sans risque de bug :)

 Sources du même auteur

Source avec Zip Source avec une capture GESTIONNAIRE DE FICHIERS MUSICAUX
Source avec Zip TUTORIEL - INTRODUCTION À WXPYTHON
Source avec Zip Source avec une capture SIMULATION DE LOTO
Source avec Zip Source avec une capture TABLEAU AVEC WXPYTHON (WXGRID)
Source avec Zip TUTORIEL - COMPILATION AVEC PY2EXE

 Sources de la même categorie

Source avec Zip Source avec une capture ILLUSTRATION DE SINUS ET DE COSINUS par calogerogigante
Source avec Zip Source avec une capture LE MOT LE PLUS LONG PAR DICO par Clempython
Source avec Zip Source avec une capture EQUATION STANDARD DE LA DROITE par calogerogigante
Source avec Zip Source avec une capture RENOMMEUR DE FICHIERS PAR LOTS par yveslc
Source avec une capture POKER : ANALYSE DES MAINS ET DES RÉSULTATS DE TOURNOIS POUR ... par guillaume_pays_cevenol

 Sources en rapport avec celle ci

Source avec Zip TUTORIEL - INTRODUCTION À WXPYTHON par aera group
Source avec Zip Source avec une capture SIMULATION DE LOTO par aera group
Source avec Zip Source avec une capture TABLEAU AVEC WXPYTHON (WXGRID) par aera group
Source avec Zip TUTORIEL - COMPILATION AVEC PY2EXE par aera group
Source avec Zip Source avec une capture ANAGRAMME PLUS! par DoudouBidou

Commentaires et avis

Commentaire de aera group le 31/05/2007 17:41:38

J'ai repéré un bug : quand on inscrit un titre avec les accents, il y a un problème avec l'unicode. Je vais résoudre ça rapidement ne vous en faite pas. Si vous repérez d'autre problèmes ou si vous avez des idées pour les prochaine version, n'esitez pas à donnez votre avis par un commentaire.

Commentaire de aera group le 01/06/2007 09:18:56

Voila, le bug est résolu (non sans mal !!!), normalement il n'y en a pas d'autre, mais on ne sait jamais, restez vigilant :)

Commentaire de sioac le 04/06/2007 18:23:16

Moi j'en ai trouvé un autre !
Un bug orthograhique : contact ne prend pas de 'e'.

^_^

Commentaire de aera group le 04/06/2007 18:27:15

Désolé, je suis nul en orthographe

Commentaire de beltegeuse le 05/06/2007 11:38:47

Très bien! je te pose juste une question car en ce moment je suis en train de placher sur quelque chose dans ce genre et j'ai vu qu tu n'utilisais aucune lib pour sauvegarder ta liste. Tu l'as fait à la main et çadoit marcher très bien!

tu peut regarder la lib suivante est spécialisée dans la lecture et la sauvegarde de fichier :

shelve (vraiment très pratique)
ps: il en existe d'autre mais je ne connai plus leur nom

Commentaire de Shakan972 le 05/06/2007 13:46:39

Source intéressante Aera surtout pour les débutant en wxpython ^^ 8/10

Et fais gaffe aux fautes d'orthographe ça vaudrai mieux :)

Commentaire de Shakan972 le 05/06/2007 13:47:56

oups j'ai oublié de mettre un "t" à vaudrai ^^

Commentaire de aera group le 05/06/2007 14:20:31

Bonjour à tous,

beltegeuse >> En effet, je n'utilise aucune librérie pour la sauvegarde (en fait, je ne savais pas que ça exister !! :) ). Ma sauvegarde se fait grace à des listes. Il y a une grande liste qui conient tous les lignes du tableau sous forme de liste : concrétement (je sais ce que je viens de dir n'est pas très claire), pour deux lignes, ont a ça : [['collone 1','collone 3','collone 3',...],['collone 1','collone 3','collone 3',...]]. La bibliothèque shelve permet en effet de créé un fichier pour enregistrer des dictionnaires introduit sous Python par {clé:définition}). Tout me semble assez bien expliquer sur le site http://quentel.pierre.free.fr/python-trad/module-shelve.html ; En cas de soucit passe par le forum.

Shakan972 >> Merci pour ta note. Sur les commentaire de ma précédente source, je t'avais dit que j'allais faire un tutoriel sur WxPython. Ne t'inquiettes pas je ne l'ai pas oublier, je m'en occupe tout de suite (je voullais d'abord finir cette source). Mais cala risque d'être long surtout que la, je vais passer le bac Français (ils vont rigoler quand ils vont voir mon orthographe !!!) donc je vais avoir peut de temps pour la programmation. Encore désolé pour les fautes d'orthographe, je suis vraiment nul dans ce domaine. Il va faloir que j'essaye de régler ca problème.

Merci à tous pour vos commentaires et bonne continuation.
______
Aéra

Commentaire de michels38 le 03/09/2007 01:02:06

Bravo pour ton développement.

Je débute en python et je comptais utiliser wx. Je vais pouvoir décortiquer le fonctionnement de ton programme.

Par rapport à la version actuelle, j'aimerai pouvoir rajouter des contrôles sur les zones (adresse mail par exemple), peut-etre rendre des zones obligatoires.

Celà pourrait devenir un bon exemple de python avec Wx

Je te souhaite bonne continuation.

(Et au fait comment c'est passé le bac de français....)

A+

Commentaire de aera group le 03/09/2007 11:11:02

Salut,

Pour l'instant, j'ai un peu arrété le développement de cette source, mais je compte y revenir dans quelque temps !!! Je pense que je vais revoir l'unicode (encore des problèmes). Je pense que c'est pour l'instant la seul source (dans celle que j'ai faite) qui mérite un développement plus pousser. En effet, cette source peut être très utile, et la distribution sur le net (en .exe bien sûr) est une possibilité envisagable.

Je suis actuellement un peu débordé, et un peu à cour d'idée. Je propose donc à tous les gens qui tiennes à faire évoluer cette source de se manifester. Cela peu allé de simples idée, à une écriture (ou ré-écriture) d'une parti du code. Toute aide est la bienvenu.

Tant que j'y suis, es que certaine personnes ont utilisé mon tutoriel sur WxPython : es ce utile d'écrire la suite, si personne ne s'y interresse ?

"(Et au fait comment c'est passé le bac de français....)" --> Bien, merci : 10 à l'oral et 15 à l'écrit (malgré les fautes)

Commentaire de aera group le 28/08/2009 13:48:07

Bonjour à tous,

Le projet de créer un Carnet d'adresse étant viable et intéressant, je pense qu'il mérite mieux que ce torchon que j'ai présenté il y a un bout de temps. La version 2 est donc en préparation, elle commence à ressembler à quelque chose de bien. La version 2.0 nommée Ara Contact devrait théoriquement comporter les avancées suivantes :

- Une nouvelle interface : l'Ara Multi Interface qui permet de gérer plusieurs fichiers dans une seul fenêtre + exit la liste moche et peut sympathique, place à des cadres de couleurs, classé par ordre alphabétique.
- Une meilleur ergonomie : plus de champs, possibilité d'ajouter une image, contrôle des champs, réorganisation des menus.
- Gestion de sauvegarde des fichiers : les fichiers sont sauvegardés par le programme dans un répertoire qu'il aura choisi (en faite un sous répertoire de l'emplacement de son installation). Cette contrainte est imposé par un problème lié au image qui sera vraisemblablement résolu dans la version 3.0
(Cette contrainte fait que l'on doit utiliser win32 donc désolé pour les amoureux de Linux ou Mac)
- Un module pour l'exportation/importation
- Une gestion de l'impression meilleur
- De l'aide (peut être tutoriel)
- Gestion total de l'Unicode (c'est là le problème avec les images)
- Un module de gestion des erreurs

Le projet avance et une vidéo sera peut être bientôt disponible. Si certain on des idées ou souhaite réaliser l'aide ou des des tutoriel (j'ai développé un programme pour ces derniers) ils sont prié de se manifester (je me réserve la programmation).
Vos réaction ou critique sont également très souhaité. Je vous remercie pour votre lecture et à bientôt !!!

Aéra

Commentaire de xeolin le 30/08/2009 21:23:09 10/10

Très bon.
Mais bon j'espère que tu vas pas présenter ça pour ton projet, ou alors va falloir sortir le dico ou une amie pour corriger les fautes (ya la moitié des boutons qui en contiennent :(  )

Je suis très fort pour trouver les fautes des autres, mais pas pour les miennes :p

pourquoi met tu des u devant toutes tes chaines de caractères ?

Et met des commentaires, parce que sinon ca va ressembler à mes sources (=très mauvais)...

Sinon ton logiciel est devenue bien complet... Mais tu devrai chercher le petit plus qui le rendra unique...

pour la date de naissance tu pourrait créer trois petites entrées combinés à des listes (pour les mois en toutes lettres) Ou alors tu pourait automatiquement convertir la date en date écrite en lettre:
03/07/92 => 3 juillet 1992

Mais sinon c'est bien :p

Nate.

Commentaire de aera group le 30/08/2009 23:34:54

Quand je parle de projet je sous entend ici projet personnel et non scolaire ou professionnel :p

Les u devant les chaines de caractères c'est pour forcer Python à travailler en Unicode (gestion des accents indispensable pour WxPython).

Si tu testes cette source normalement à la sauvegarde tu auras une erreur :(
En effet suite au modification des version de Python et WxPython (qui géraient chaqu'un l'encodage Unicode différemment) ce programme ne fonctionne plus (pour l'enregistrement) ...
En gros c'est la honte absolu pour moi, je propose un programme incohérent et bugé alors que je cherche la moindre petite faille sur les programmes des autres ... (bon j'ai une excuse, il fonctionnait sous ma version de Python/Wx à l'époque)

D'où la nécessité d'une mise à jour importante : refonte graphique, nouvelles options, un semblant de cryptage (juste pour le fun), module de sécurité, contrôle des champs, ...
Le détail partiel est dans mon post précédent ...

Voila, pour te faire plaisir je passerais par une copine (autant la faire travailler un peu, j'étais à cour d'idée pour l'embêter :p)

La nouvelle version pourra peut être (pas sûr) supporter les anciennes sauvegarde (en tout cas celle qui ont pu être écrite).

Voila j'espère pouvoir déposer le dimanche 13 septembre une vidéo montrant un apercu de la nouvelle version et une date de sortie ...

Ciao à tous (Xeolin serait tu nais un 3 juillet ? :p)

Commentaire de aera group le 14/09/2009 00:00:28

Voici la vidéo à cette adresse : http://www.dailymotion.com/video/xah8ae_ara-contact-presentation-de-la-vers_tech
Malheureusement la qualité n'est pas au rendez vous et il est impossible de voir les détails d'où un autre lien de téléchargement : http://www.megaupload.com/?d=W7THYFAT

Bon visionnage :p

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Liste le contenu d'un répertoire [ par MHI ] Le code suivant me génére un fichier vide, alors que mon répertoire contient bien un répertoire et 3 fichiers :import osimport dircachefic = open('Lis wxPython et DDE [ par DoudouBidou ] Bonjour,j'utilise la liaison DDE pour dialoguer entre python et une application sous windows 2000j'ai trouvé (un peu par hasard) un module DDE pour gé [wxPython] apperçu avant impression multipages [ par dj_djocker ] au secour!!!!!!une semaine que je cherche partout mais rien a faire.a travers un logiciel cr&#233;e en python je cr&#233;e une impression d'au moins u wxPython [ par MHI ] Bonjour Je recherche une doc en fran&#231;ais expliquant simplement comment cr&#233;&#233; une fen&#234;tre, des boutons et une listebox avec wxPython wxpython : afficher et effacer des images [ par steede ] Bonjour,J'ai besoin dans mon application d'affiicher des images et de les remplacer par d'autres en fonction des clics de la souris.Je sais les affich [help] traitement de formulaires et recherche de DOC [ par johanb ] Bonjour &#224; tous, je viens de me lancer dans le python et j'i de gros probl&#232;mes avec la syntaxe que je ne connias pas bien.Donc tout d'abord s liste des process en cours [ par rodrigos ] Bonjour, Je suis sous windows et je cherche &#224; obtenir la liste des process en cours sur le pc. La seule foncyion que j'ai rouv&#233; est la fonc Zope: Contenu d'une liste en fonction d'une autre [ par keumlebarbare ] AU SECOURS!!!! Je suis tout ce qu'il y a de plus d&#233;butant en Zope, et je crois que si je continue &#224; gal&#233;rer comme ca, je me (re)met a Un Canvas comme dans Tkinter, mais pour wxPython [ par samurize ] Slt tout le monde. &nbsp; Voila tout est dans le titre (ou a peu pres&nbsp; ) : &nbsp; Je suis &#224; la recherche d'un module pouvant s'integrer da wxPython et Unicode [ par tomazi75 ] Bonjour, &nbsp;J'aimerais afficher le caract&#232;re u'\u2661' (symbole 'pique' comme pour les cartes &#224; jouer). Pas d'erreur, mais &#231;a affich


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mars 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode

Photothèque

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,655 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales