+ return random.choice(self.quotesfrom(author))
+
+ def search(self, inquote=None, author=None, regexp=False):
+ """Fait une recherche dans les quotes."""
+ if regexp:
+ if inquote is None:
+ inquote = ".*"
+ if author is None:
+ author = ".*"
+ qreg = re.compile(inquote, flags=re.UNICODE)
+ areg = re.compile(author, flags=re.UNICODE)
+ l = [q for q in self.quotelist if qreg.match(q.content) and areg.match(q.author)]
+ else:
+ if inquote is None:
+ inquote = ""
+ if author is None:
+ author = ""
+ l = [q for q in self.quotelist if inquote in q.content and author in q.author]
+ return l
+
+ def search_authors(self, author=None, regexp=False):
+ """Renvoie la liste des auteurs contenant ``author`` ou qui matchent la regexp."""
+ if regexp:
+ if author is None:
+ author = ".*"
+ areg = re.compile(author, flags=re.UNICODE)
+ l = list(set([q.author for q in self.quotelist if areg.match(q.author)]))
+ else:
+ if author is None:
+ author = ""
+ l = list(set([q.author for q in self.quotelist if author in q.author]))
+ return l
+
+def dump(quotedb, dump_file=None):
+ """Pour exporter les quotes dans un format readable vers un fichier."""
+ if dump_file is None:
+ dump_file = config.quote_dump_file
+ t = "\n".join([q.full_str() for q in quotedb.quotelist]) + "\n"
+ with open(dump_file, "w") as f:
+ f.write(t)
+
+def restore(dump_file=None):
+ """Crée un DB de quotes en parsant le contenu d'un fichier de dump."""
+ if dump_file is None:
+ dump_file = config.quote_dump_file
+ with open(dump_file) as f:
+ t = f.read()
+ t = t.decode("utf-8") # Oui, ça peut fail, mais on ne doit alors pas continuer
+ l = [m.groupdict() for m in quote_matcher_with_timestamp.finditer(t)]
+ # On instancie les quotes grâce aux dicos qui ont déjà la bonne tronche
+ l = [Quote(**q) for q in l]
+ newquotedb = QuoteDB()
+ newquotedb.quotelist = l
+ return newquotedb